前些日子再博客上转载了一篇核算器的C程序,因为这些日子一向忙于考试,也抽不出时刻来重写一下根据C51的核算器,昨夜考完信号处理,回来就着手写,一向弄到清晨3点多,现面把代码帖出来和我们一同共免,因为时刻匆促,代码部分或许还有缺乏,而且程序仅仅再我的试验板上调试,如有缺乏请多多执教,程序时C和汇编混合编程,汇编部分值用到延时的处理,其他代码都用C写的,期望哪为高人可以写出功用更为强壮的核算器程序一同共享,关于我的程序,哪位博友增添了更多功用的话,期望发到回复里,以共同进步!
程序代码如下:
#include
#define uchar unsigned char
#define uint unsigned int
bit NumSem;//前后操作数的互斥信号量
bit equ;//等号判别
bit clr;//清零标志
bit add;//加标志
bit dec;//减标志
bit mul;//乘标志
bit div;//除标志
bit op;//算术符号标志
uchar KeyNum;//键值
uint result;//核算成果
uint PreNum,LatNum;//核算的两个操作数前操作数,后操作数
uchar KeyPos;
uchar DisLed[]={0xC0,0xF9,0xA4,0xB0,0x99,//LED数码七段表
0x92,0x82,0xF8,0x80,0x90};
uchar NumBufe[]={0,0,0,0};
//sbit P10=P1^0;
//sbit P11=P1^1;
//sbit P12=P1^2;
//sbit P13=P1^3;
void T0Intal(void);//定时器0初始化程序
void DisPlay(void);//显现程序
void ResultNum(void);//核算器运算成果
void Clear(void);//清零程序
void Delay_510(void);//延时510us程序用汇编编写
void ChangeNum(uchar *p,uchar nCount);//NumBufe[]移位程序
void main(void)
{
T0Intal();
while(1)
{
if(NumSem)
{
PreNum=NumBufe[3]*1000+NumBufe[2]*100+NumBufe[1]*10+NumBufe[0];
NumBufe[4]=0;
NumSem=0;
}
if(op)
{
if(PreNum!=0)
{
if(NumBufe[4]==0)
{
NumSem=1;
}
if(equ)
{
if(NumBufe[4]!=0)
{
LatNum=NumBufe[3]*1000+NumBufe[2]*100+NumBufe[1]*10+NumBufe[0];
//DisLed[]=0;
KeyPos=0;
}
ResultNum();//核算器成果核算
//DisPlay();//显现核算成果
}
}
else Clear();
}
if(clr)
{
Clear();
}
DisPlay();//显现核算成果
}
}
void T0Intal(void)
{
TMOD=0x01;
TH0=(65536-20000)/256;
TL0=(65536-20000)%256;
EA=1;
ET0=1;
TR0=1;
}
void DisPlay(void)
{
//uchar one,two,three,four;
//one=result/1000;
P2=DisLed[NumBufe[3]];
P0=0xFE;
Delay_510();
//two=(result-one*1000)/100;
P2=DisLed[NumBufe[2]];
P0=0xFD;
Delay_510();
//three=(result-one*1000-two*100)/10;
P2=DisLed[NumBufe[1]];
P0=0xFB;
Delay_510();
//four=(result-one*1000-two*100)%10;
P2=DisLed[NumBufe[0]];
P0=0xF7;
Delay_510();
}
void ResultNum(void)
{
if(op)
{
if(add)
{
result=PreNum+LatNum;
}
if(dec)
{
result=PreNum-LatNum;
}
if(mul)
{
result=PreNum*LatNum;
}
if(div)
{
result=PreNum/LatNum;
}
}
//return result;
//unsigned char
//uchar one,two,three;
//one=result/1000;
NumBufe[3]=result/1000;
NumBufe[2]=(result-NumBufe[3]*1000)/100;
//NumBufe[2]=two;
NumBufe[1]=(result-NumBufe[3]*1000-NumBufe[2]*100)/10;
//NumBufe[1]=three;
NumBufe[0]=(result-NumBufe[3]*1000-NumBufe[2]*100)%10;
}
void Clear(void)
{
// if(Clear)
//{
NumBufe[0]=0;
NumBufe[1]=0;
NumBufe[2]=0;
NumBufe[3]=0;
PreNum=0;
LatNum=0;
result=0;
NumSem=0;
KeyPos=0;
clr=0;
equ=0;
add=0;
dec=0;
mul=0;
div=0;
op=0;
// }
}
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/zhudong/259348.html