c语言51
⑴ 51单片机,帮忙写个c语言程序
//好像是这个头文件 好久没玩51了
#include <reg51.h>
//------------宏定义---------------//
#define uchar unsigned char
#define uint unsigned int
#define BUTTON1 1 //按键1
#define BUTTON2 2 //按键2
//-----------变量-----------//
uchar Counter = 0; //统计按键次数
/*-------管脚定义 --------//
记得是sbit P13 = P1^3;
忘了,你自己定义吧,我直接写程序
*/
//-------------延时---------------//
void Delay(uchar x)
{
uchar i,j;
for(i = 0; i++; i < x)
for(j = 0; j++; j < 200)
}
//------------按键扫描------------//
uchar ButtonScan (void)
{
uchar ButtonNum = 0;
if(P13 == 0)
{
/*延时防止按键抖动,如果你的晶振是12M的话,
如果是其他的你只要让延时在30ms就可以了*/
Delay(150);
if(P13 == 0)
while(!P13); /*等待按键松开*/
ButtonNum = BUTTON1;
}
if(P14 == 0)
{
Delay(150);
if(P14 == 0)
while(!P14); /*等待按键松开*/
ButtonNum = BUTTON2;
}
return ButtonNum;
}
//----------按键判断-------------//
void ButtonJugde (void)
{
switch(ButtonScan())
{
case 1: //增加
if (Counter != 40)
Counter++;
break;
case 2: //减小
if (Counter != 0)
Counter--;
break;
default: break;
}
}
//---------LED点亮处理--------//
uchar LED (void)
{
/*我这里把你所说的“一号灯”理解为P2.0所对应的二极管,
“二号灯”理解为P2.1所对应的二极管。。。一次类推
根据你的实际电路情况调整*/
uchar LedEnable;
if((Counter > 0) && (Counter <= 5))
{
/*我理解你的二极管是接地的,然后高电平点亮
根据你的实际电路情况调整*/
LedEnable = 0x01;
}
if((Counter > 5) && (Counter <= 10))
{
LedEnable = 0x03;
}
if((Counter > 10) && (Counter <= 15))
{
LedEnable = 0x07;
}
if((Counter > 15) && (Counter <= 20))
{
LedEnable = 0x0f;
}
if((Counter > 20) && (Counter <= 25))
{
LedEnable = 0x01f;
}
if((Counter > 25) && (Counter <= 30))
{
LedEnable = 0x3f;
}
if((Counter > 30) && (Counter <= 35))
{
LedEnable = 0x7f;
}
if((Counter > 35) && (Counter <= 40))
{
LedEnable = 0xff;
}
return LedEnable;
}
//--------------主函数------------------//
void main(void)
{
while(1)
{
ButtonJugde (); //按键扫描
P2 = LED(); //点亮二极管
}
}
免责声明:
以上程序为本人(chen bolin)所写,但是未通过本人验证。
任何人可以使用或修改本代码,包括商业用途。本人不承担任何责任。
具体请遵守GPL协议。
我没有编译,你自己编译看看吧,别忘了把管脚定义补全了。应该可以实现的。如果有什么不明白的可以到我的主页留言。
⑵ 51单片机C语言编程
// 51单片机C语言编程,这个时钟+秒表可以参考一下。
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
sbit qingling=P1^0; //清零
sbit tiaofen=P1^1; //调分
sbit tiaoshi=P1^2; //调时
sbit sounder=P1^7; //naozhong
uint a,b;
uchar hour,minu,sec, //时钟
hour0,minu0,sec0,//秒表
hour1,minu1,sec1;
h1,h2,m1,m2,s1,s2,//显示位
k,s;//状态转换标志
uchar code select[]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};
uchar code table[]= {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
/*****************函数声明***********************/
void keyscan();
void init();
void delay(uchar z);
void display(uchar,uchar,uchar);
void sounde();
/*****************主函数*************************/
void main()
{
init();
while(1)
{
while(TR1)
{
keyscan(); //扫描函数
while(s==1) //s是状态标志,当s=0时,闹钟取消。s=1时,设定闹钟时间(也是通过调时,调分函数);
{ //s=2时,闹钟工作,时间与设定时刻一致时,闹钟响(一分钟后自动关闭,可手动关闭)。再次切换,s=0.
keyscan(); //s状态切换(0-》1-》2-》0)通过外部中断1实现。
display(hour1,minu1,sec1); //闹钟时刻显示
}
display(hour0,minu0,sec0);//时钟表显示
while(k) /*k是秒表状态(0-》1-》2-》0)通过外部中断0实现。0秒表关;1秒表从零计时;2秒表停,显示计时时间*/
{
display(hour,minu,sec); //秒表显示
}
}
}
}
/*****************初始化函数***********************/
void init()
{
a=0;
b=0;
k=0;
s=0;
hour0=0;
minu0=0;
sec0=0;
hour=0;
minu=0;
sec=0;
hour1=0;
minu1=0;
sec1=0;
TMOD=0x11; //定时器0,1工作于方式1;赋初值
TH0=(65536-5000)/256;
TL0=(65536-5000)%256;
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
EA=1;
EX0=1; //秒表中断
EX1=1; //闹钟设定中断
ET0=1;
ET1=1;
IT0=1; //边沿触发方式
IT1=1;
PX0=1;
PX1=1;
TR0=0; //初始,秒表不工作
TR1=1; //时钟一开始工作
}
/*****************定时器0中断*************/
void timer0_int() interrupt 1 //秒表
{
TH0=(65536-5000)/256;
TL0=(65536-5000)%256;
a++;
if(a==2)
{
a=0;
sec++;
if(sec==100)
{
sec=0; //毫秒级
minu++;
if(minu==60)
{
minu=0; //秒
hour++;
if(hour==60) //分
{
hour=0;
}
}
}
}
}
/*************外部中断0中断函数************/
void ex0_int() interrupt 0
{
k++;
if(k==3)
k=0;
if(k==1)
{
TR0=~TR0;
if(TR0==1)
{
hour=0;
minu=0;
sec=0;
}
}
if(k==2)
{
TR0=~TR0;
}
}
/*************外部中断1中断函数************/
void ex1_int() interrupt 2
{
s++;
if(s==3)
s=0;
}
/*************定时器1中断****************/
void timer1_int() interrupt 3 //控制时钟工作
{
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
if(s==2)
{
if(hour1==hour0 && minu0==minu1)
sounde();
}
b++;
if(b==20)
{
b=0;
sec0++;
if(sec0==60)
{
sec0=0;
minu0++;
if(minu0==60)
{
minu0=0;
hour0++;
if(hour0==24)
hour0=0;
}
}
}
}
/*************键盘扫描****************/
void keyscan()
{
if(s==1)
{
if(qingling==0)
{
delay(10);
if(qingling==0)
{
sec1=0;
minu1=0;
hour1=0;
}
}
if(tiaofen==0)
{
delay(10);
if(tiaofen==0)
{
minu1++;
if(minu1==60)
{
minu1=0;
}
while(!tiaofen);
}
}
if(tiaoshi==0)
{
hour1++;
if(hour1==24)
{
hour1=0;
}
while(!tiaoshi);
}
}
else //调整时钟时间
{
if(qingling==0)
{
delay(10);
if(qingling==0)
{
sec0=0;
minu0=0;
hour0=0;
}
}
if(tiaofen==0)
{
delay(10);
if(tiaofen==0)
{
minu0++;
if(minu0==60)
{
minu0=0;
}
while(!tiaofen);
}
}
if(tiaoshi==0)
{
hour0++;
if(hour0==24)
{
hour0=0;
}
while(!tiaoshi);
}
}
}
/*************显示函数****************/
void display(uchar hour,uchar minu,uchar sec)
{
h1=hour/10;
h2=hour%10;
m1=minu/10;
m2=minu%10;
s1=sec/10;
s2=sec%10;
P0=0xff;
P2=table[h1];
P0=select[7];
delay(5);
P0=0xff;
P2=table[h2];
P0=select[6];
delay(5);
P0=0xff;
P2=0x40;;
P0=select[5];
delay(5);
P0=0xff;
P2=table[m1];
P0=select[4];
delay(5);
P0=0xff;
P2=table[m2];
P0=select[3];
delay(5);
P0=0xff;
P2=0x40;
P0=select[2];
delay(5);
P0=0xff;
P2=table[s1];
P0=select[1];
delay(5);
P0=0xff;
P2=table[s2];
P0=select[0];
delay(5);
}
/*************闹钟函数****************/
void sounde()
{
sounder=~sounder;
}
/*************延时函数****************/
void delay(uchar z)
{
int x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
⑶ 用c语言写51单片机
#include<reg51.h>
#defineucharunsignedchar
sbitkey1=P1^0;
sbitkey2=P1^1;
sbitkey3=P1^2;
sbitkey4=P1^3;
sbitled1=P1^4;
sbitled2=P1^5;
main()
{
if(key1==0)
{
while(key1==0);
led1=0;
led2=1;
}
if(key2==0)
{
while(key2==0);
led1=1;
led2=0;
}
if(key3==0)
{
while(key3==0);
led1=0;
led2=0;
}
if(key4==0)
{
while(key4==0);
led1=1;
led2=1;
}
}
⑷ 关于51C语言的
在small模式下,变量默认存储在data区,可以用idata,pdata,xdata,code制定变量的存储位置。
256b的ram中前128b是data区(00H-0FFH)。
4个工作寄存器区R0-R7(00H-1FH),一般函数默认使用using 0即工作寄存器0,中断函数使用剩下的3个,比如t0中断使用using 1,t2用using 2,ex0用using 3。
80H-FFH是难理解的部分,因为特殊功能寄存器的地址(注意只是地址)也在这个范围内。那么单片机是怎么区分是ram还是寄存器呢?答案是通过寻址方式。这就是80H-FFH只能用寄存器间接寻址的原因。
举个列子,80H是P0的地址。
mov 80H,#10H (把P0口置为16)
mov R0, 80H
mov @R0 #10H (把ram中的80H置为16)
如果你的程序没定义其他变量,并且没有使用using 1、using 2、using 3,那么tab[]的地址是08H-11H。剩下的是堆栈,所以复位后sp的地址是11H。
⑸ 51单片机C语言
&&不行么?
是while 大哥。
给分
⑹ C语言51单片机 希望给出每句的意思 很急 谢谢!!!
具体哪里不懂?
你不要说每一句都不懂啊……这样的话你与其在这里问程序还不如回去好好看书……
⑺ 51单片机C语言这个是什么意思啊
定义一个了一uchar类型的变量 temp1,和一个uchar类型的数组,数组包含10个元素。0X开头表示16进制的数字。 例如:0X81 = 129。 从名字来看,uchar应该是 unsigned char的意思,即无符号的char类型(1个byte),表示的数值范围是 0 ~ 255。
⑻ 51单片机c语言
我有数码管。。。你那个没用过 爱莫能助