版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Lessonl乍业1、用位操作点亮第一个发光管.适用TX-1C单片机实验板晶振为11.0592M/*/#include<reg52.h> /52 单片机头文件sbit led1=P1A0;单片机管脚位声明void main()/主函数(led1=0;将单片机 P1.0 口清零while(1);程序停止在这里,在后面会讲到为什么这样写。2、用总线操作点亮第一个发光管/*/ #include<reg52.h> /52 单片机头文件void main()/主函数(P1=0xfe;/将单片机P1 口的8个口由高到低分别赋值为11111110while(1);程序停止在这里,在后
2、面会讲到为什么这样写。3、用位操作点亮最后一个发光管./*/#include<reg52.h> /52 单片机头文件sbit led8=P1A7;单片机管脚位声明void main()/主函数(led8=0;将单片机 P1.7 口清零while(1);程序停止在这里,在后面会讲到为什么这样写。4、用总线操作点亮最后一个发光管/*/ #include<reg52.h> /52 单片机头文件void main()/主函数(P1=0x7f;将单片机P1 口的8个口由高到低分别赋值为01111111while(1);程序停止在这里,在后面会讲到为什么这样写。5、用位操作点亮1,
3、3,5,7发光管./*/ #include<reg52.h> /52 单片机头文件sbit led1=P1A0;单片机管脚位声明sbit led3=P1A2;单片机管脚位声明sbit led5=P1A4;单片机管脚位声明sbit led7=P1A6;单片机管脚位声明void main()/主函数(led1=0;将单片机P1.0口清零led3=0;将单片机P1.2口清零led5=0;将单片机P1.4口清零led7=0;将单片机P1.6口清零while(1);程序停止在这里,在后面会讲到为什么这样写。6、用总线操作点亮1,3,5,7发光管./*/#include<reg52.h&
4、gt; /52 单片机头文件void main()/主函数(P1=0xaa;将单片机P1 口的8个口由高到低分别赋值为10101010while(1);程序停止在这里,在后面会讲到为什么这样写。7、用位操作点亮2,4,5,6发光管./*/#include<reg52.h> /52 单片机头文件sbit led2=P1A1;单片机管脚位声明sbit led4=P1A3;单片机管脚位声明sbit led5=P1A4;单片机管脚位声明sbit led6=P1A5;单片机管脚位声明void main()/主函数(led2=0;将单片机P1.1口清零led4=0;将单片机P1.3口清零led
5、5=0;将单片机P1.4口清零led6=0;将单片机P1.5口清零while(1);程序停止在这里,在后面会讲到为什么这样写。8、用总线操作点亮2,4,5,6发光管./*/#include<reg52.h> /52 单片机头文件void main()/主函数(P1=0xc5;将单片机P1 口的8个口由高到低分别赋值为11000101while(1);程序停止在这里,在后面会讲到为什么这样写。9、尝试让第一个发光管闪烁.(程序看不懂没关系,后面章节会有详细讲解 ) /*/ #include<reg52.h> /52 单片机头文件 sbit led1=P1A0;单片机管脚位
6、声明void main()/主函数(unsigned int i; / 定义一个 int 型变量while(1) (i=50000;/变量赋初值为 50000led1=0;/点亮灯while(i-); / 延时i=50000;led1=1;/熄灭灯while(i-);10、尝试写出流水灯程序(程序看不懂没关系,后面章节会有详细讲解)/*/#include<reg52.h> /52 单片机头文件void main()/主函数(unsigned int i; / 定义一个 int 型变量while(1) (i=50000;/变量赋初值为50000P1=0xfe;/点亮第一个灯while
7、(i-);延时i=50000;/变量赋初值为50000P1=0xfd;/点亮第二个灯while(i-);延时i=50000;/变量赋初值为50000P1=0xfb;/点亮第三个灯while(i-);延时i=50000;/变量赋初值为50000P1=0xf7;/点亮第四个灯while(i-);延时i=50000;/变量赋初值为50000P1=0xef;/点亮第五个灯while(i-);延时i=50000;/变量赋初值为50000P1=0xdf;/点亮第六个灯while(i-);延时i=50000;/变量赋初值为50000P1=0xbf;/点亮第七个灯while(i-);延时i=50000;/变量
8、赋初值为50000P1=0x7f;/点亮第八个灯while(i-);延时Lesson 21、 第一个发光管以间隔200ms闪烁/*/#include<reg52.h> /52 单片机头文件#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit led1=P1A0;单片机管脚位声明void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms.(/delay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-
9、)for(y=110;y>0;y-);void main()/ 主函数(while(1)大循环(led1=0;点亮小灯delay(200); / 延时 200 毫秒led1=1; 熄灭小灯delay(200); / 延时 200 毫秒2、 8个发光管由上至下间隔1s流动其中每个管亮500ms灭500ms席时蜂鸣器响灭时关闭蜂鸣器,一直重复下去。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar
10、unsigned char / 宏定义sbit beep=P2A3;void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms.(/delay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数(uchar a;a=0xfe;while(1)大循环(P1=a;点亮小灯beep=0;/开启蜂鸣器delay(500); 延时 500 毫秒P1=0xff;/熄灭小灯beep=1;/关闭蜂鸣器delay(500); 延时 500
11、 毫秒a=_crol_(a,1); /将a变量循环左移一位 3、8个发光管来回流动,每个管亮100ms流动时让蜂鸣器发出"滴滴'声。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit beep=P2A3;void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms.(/de
12、lay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数(uchar a,i;while(1)大循环(a=0xfe;/赋初值for(i=0;i<8;i+)/左移(P1=a;点亮小灯beep=0;/开启蜂鸣器delay(50); 延时 50 毫秒beep=1;/关闭蜂鸣器delay(50); /再延时50毫秒a=_crol_(a,1); /将a变量循环左移一位a=0x7f;for(i=0;i<8;i+) /右移(P1=a;点亮小灯beep=0;/开启蜂鸣器delay(50)
13、;/ 延时 50 毫秒beep=1;/关闭蜂鸣器delay(50);/再延时50毫秒a=_cror_(a,1); /将a变量循环右移一位4、用8个发光管演示出8位二进制数累加过程。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms.(/de
14、lay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数(uchar a;while(1)大循环(a+;P1=a;delay(200);5、8个发光管间隔200ms由上至下,再由下至上,再重复一次,然后全部熄 灭再以300ms间隔全部闪烁5次。重复此过程/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define
15、 uchar unsigned char / 宏定义void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms./delay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数uchar a,i,j;while(1)大循环for(j=0;j<2;j+)a=0xfe; 赋初值for(i=0;i<8;i+)/ 左移P1=a; 点亮小灯delay(200); / 延时 200 毫秒a=_crol_(a,1); /将
16、a变量循环左移一位a=0x7f;for(i=0;i<8;i+) / 右移P1=a; 点亮小灯delay(200); / 延时 200 毫秒a=_cror_(a,1); /将a变量循环右移一位P1=0xff; /全部熄灭for(j=0;j<10;j+)delay(300); / 延时P1=P1;/全部取反10次,既闪烁5次6、间隔300ms第一次一个管亮流动一次,第二次两个管亮流动,依次到 8个管亮,然后重复整个过程。/*/#include<reg52.h>/52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#defin
17、e uint unsigned int / 宏定义#define uchar unsigned char / 宏定义void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms./delay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数uchar a,i,j;while(1)大循环a=0xfe; 赋初值for(j=0;j<8;j+)for(i=0;i<8-j;i+)/左移P1=a;点亮小灯delay(20
18、0); / 延时 200 毫秒a=_crol_(a,1); /将a变量循环左移一位a=_crol_(a,j); /补齐,方便下面的左移一位P1=0xff; /全部关闭a=a<<1;左移一位让多一个灯点亮7、间隔300ms先奇数亮再偶数亮,循环三次;一个灯上下循环三次;两个分别 从两边往中间流动三次;再从中间往两边流动三次;8个全部闪烁3次;关闭发光管,程序停止。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#d
19、efine uchar unsigned char / 宏定义void delay(uint z) 延时函数,z的取值为这个函数的延时ms数,如 delay(200);大约延时200ms./delay(500);大约延时 500ms.uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void main()/ 主函数uchar a,i,j;for(j=0;j<3;j+)/ 寄偶交替P1=0x55; 点亮小灯 delay(300); / 延时 300 毫秒 P1=0xaa;delay(300); / 延时 300 毫秒 for(j=0;j<
20、3;j+)/ 流水灯a=0xfe;for(i=0;i<8;i+)P1=a;点亮小灯delay(300); / 延时 300 毫秒 a=_crol_(a,1);P1=0xff; for(j=0;j<3;j+)/从两边往中间流P1=0x7e; 点亮小灯 delay(300); / 延时 300 毫秒 P1=0xbd;delay(300); / 延时 300 毫秒P1=0xdb; 点亮小灯 delay(300); / 延时 300 毫秒P1=0xe7;delay(300); / 延时 300 毫秒 P1=0xff;for(j=0;j<3;j+)/从中间往两边流(P1=0xe7; 点
21、亮小灯 delay(300); / 延时 300 毫秒 P1=0xdb;delay(300); / 延时 300 毫秒 P1=0xbd; 点亮小灯 delay(300); / 延时 300 毫秒 P1=0x7e;delay(300); / 延时 300 毫秒 P1=0xff;for(j=0;j<6;j+)/ 全部闪烁(P1=P1; 点亮小灯 delay(300); / 延时 300 毫秒 P1=0xff;while(1);Lesson31、利用定时/计数器T0从P1.0输出周期为1s的方波,让发光二极管以1HZ闪 烁。/*/#include<reg52.h> /52 单片机头
22、文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit P1_0=P1A0;uchar tt;void main()/ 主函数(TMOD=0x01;/设置定时器0为工作方式1TH0=(65536-50000)/256;TL0=(65536-50000)%256;EA=1;/开总中断ET0=1;/开定时器0中断TR0=1;/启动定时器0while(1);/等待中断产生 void timer0() interrupt 1(TH0=
23、(65536-50000)/256;TL0=(65536-50000)%256;tt+;if(tt=20)(tt=0;P1_0=P1_0;2、利用定时/计数器T1产生定时时钟,由P1 口控制8个发光二极管,使8个指示 灯依次一个一个闪动,闪动频率为10次/秒(8个灯依次亮一遍为一个周期),循环。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit P1_0
24、=P1A0;uchar tt,a;void main()/ 主函数(TMOD=0x01;/设置定时器0为工作方式1TH0=(65536-50000)/256;TL0=(65536-50000)%256;EA=1;/开总中断ET0=1;/开定时器0中断TR0=1;/启动定时器0a=0xfe;while(1);/等待中断产生 void timer0() interrupt 1(TH0=(65536-50000)/256;TL0=(65536-50000)%256;tt+;if(tt=2)(tt=0;P1=a;a=_crol_(a,1);3、同时用两个定时器控制蜂鸣器发声,定时器 0控制频率,定时器
25、1控制同个 频率持续的时间,间隔 2s依次输出1, 10, 50,100, 200,400,800,1k (hz)的方 波/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit beep=P2A3;uchar tt;uint fre,flag;void main()/ 主函数(fre=50000;beep=0;TMOD=0x11;/设置定时器0,定时器1为工
26、作方式1TH0=(65536-fre)/256;TL0=(65536-fre)%256;TH1=(65536-50000)/256;TL1=(65536-50000)%256;EA=1;/开总中断ET0=1;/开定时器0中断ET1=1;TR1=1;TR0=1;/启动定时器0while(1);/等待中断产生void timer0() interrupt 1/ 定时器 0 中断TR0=0;/进中断后先把定时器0中断关闭,防止内部程序过多而造成中断丢失TH0=(65536-fre)/256;TL0=(65536-fre)%256;tt+;if(flag<40)以下几个if分别用来选取不同的频率
27、if(tt=10)tt=0;fre=50000;beep=beep;if(flag>=40&&flag<80)tt=0;fre=50000;beep=beep;if(flag>=80&&flag<120)tt=0;fre=10000;beep=beep;if(flag>=120&&flag<160)tt=0;fre=5000;beep=beep;if(flag>=160&&flag<200)(tt=0;fre=2500;beep=beep;if(flag>=200&&a
28、mp;flag<240)(tt=0;fre=1250;beep=beep;if(flag>=240&&flag<280)(tt=0;fre=625;beep=beep;if(flag>=280&&flag<320)(tt=0;fre=312;beep=beep;if(flag>=320&&flag<360)(tt=0;fre=156;beep=beep;TR0=1;void timer1() interrupt 3 定时器1中断用来产生 2秒时间定时 (TH1=(65536-50000)/256;TL1=
29、(65536-50000)%256;flag+;if(flag=360)(flag=0;fre=50000;4、用定时器以间隔500MS在6位数码管上依次显示 0、1、2、3.C D、E、F, 重复。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit dula=P2A6;/数码管段选锁存端sbit wela=P2A7; /数码管位选锁存端 uchar n
30、um,tt;uchar code table=(0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;void main()(num=0;tt=0;TMOD=0x01;/设置定时器0为工作方式1TH0=(65536-50000)/256;TL0=(65536-50000)%256;EA=1;/开总中断ET0=1;/开定时器0中断TR0=1;/启动定时器0dula=1;P0=0x3f; 给段开始送显示 0。dula=0;/关闭段选锁存端,防止开始时出现乱码。wela=1;/11101010P
31、0=0xc0; /打开六个数码管位选wela=0;while(1)(if(tt=10)每进入10次中断即为500ms,执行一次显示变化。(tt=0;num+;if(num=16)num=0;dula=1;P0=tablenum;dula=0;+!992%(00009-9£999)=011!99S/(00009-9e999)=0Hl )堀市。器闻老 / L ldPLU9M 00J91X9 P!。入Lesson41、利用动态扫描方法在六位数码管上显示出稳定的654321./*/#include<reg52.h> /52 单片机头文件#include <intrins.h
32、> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义 sbit dula=P2A6;/数码管段选锁存端sbit wela=P2A7; /数码管位选锁存端 uchar code table=(/数码管显示编码0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71;void display(uchar,uchar,uchar,uchar,uchar,uchar); / 函数声
33、明 void delay(uint);void main()(while(1)( display(6,5,4,3,2,1);始终显示void display(uchar one,uchar two,uchar three,uchar four,uchar five,uchar six)(dula=1;P0=tableone;送段数据dula=0;P0=0xff; /送位数据前关闭所有显示防止打开位选锁存后段选数据通过位选锁存器 wela=1;P0=0xfe;wela=0;delay(1);dula=1; P0=tabletwo; dula=0; P0=0xff; wela=1; P0=0xfd
34、; wela=0;delay(1);dula=1;P0=tablethree;dula=0;P0=0xff;wela=1;P0=0xfb;wela=0;delay(1);dula=1;P0=tablefour;dula=0;P0=0xff;wela=1;P0=0xf7;wela=0;delay(1);dula=1;P0=tablefive;dula=0;P0=0xff;wela=1;P0=0xef;wela=0;delay(1);dula=1;P0=tablesix;dula=0;P0=0xff;wela=1;P0=0xdf;wela=0;delay(1);void delay(uint z)
35、延时子函数uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);2、用动态扫描方法和定时器1在数码管的前三位显示出秒表,精确到1%秒,即最后一位显示1%秒,一直循环下去/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit dula=P2A6;/数码管段选锁存端sbit wela=P2A7; /数码管位选锁存端uch
36、ar ge,shi,bai;uint tt;uchar code table=(0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;void display(uchar,uchar,uchar); / 函数声明void delay(uint);void main()(TMOD=0x10;/设置定时器1为工作方式1TH1=(65536-10000)/256;TL1=(65536-10000)%256;EA=1;/开总中断ET1=1;/开定时器1中断TR1=1;/启动定时器1while(1)
37、(display(bai,shi,ge);void exter0() interrupt 3/ 定时器 1 中断(TH1=(65536-10000)/256;TL1=(65536-10000)%256;tt+;if(tt=1000)tt=0;bai=tt/100;shi=tt%100/10;ge=tt%10;void display(uchar one,uchar two,uchar three)(dula=1;P0=tableone;送段数据dula=0;P0=0xff;/送位数据前关闭所有显示,防止打开位选锁存后段选数据通过位选锁存器wela=1;P0=0xfe;wela=0;delay(
38、1);dula=1;P0=tabletwo;dula=0;P0=0xff;wela=1;P0=0xfd;wela=0;delay(1);dula=1;P0=tablethree;dula=0;P0=0xff;wela=1;P0=0xfb;wela=0;delay(1);void delay(uint z)延时子函数(uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);3、利用动态扫描和定时器1在数码管上显示 出从765432开始以1/10秒的速度 往下递减直至765398并保持显示此数,与此同时利 用定时器0以500MS速度 进行流水灯从上至下移动,
39、当数码管上数减到停止时,实验板上流水灯也停止然后全部开始闪烁,3秒后(用T0定时)流水灯全部关闭、数码管上显示出 "HELLO"到此保持住。/*/#include<reg52.h> /52 单片机头文件#include <intrins.h> /包含有左右循环移位子函数的库#define uint unsigned int / 宏定义#define uchar unsigned char / 宏定义sbit dula=P2A6;sbit wela=P2A7;uchar code table=( / 显示数据编码0x3f,0x06,0x5b,0x4f,
40、0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x76,0x79,0x38,0x3f,0;uchar temp,t0,t1,bai,shi,ge,flag,flag1;uint shu;void init();/ 函数声明void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge);void delay(uint z) / 延时子函数(uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);void ma
41、in()/ 主函数(init();while(1)(if(flag1!=1) /如果flagi不再等于1则显示数据display(7,6,5,bai,shi,ge);elsedisplay(16,17,18,18,19,20);/ 否则显示 hellovoid init()/初始化函数(shu=432;temp=0xfe;P1=temp;TMOD=0x11;TH0=(65536-50000)/256; / 定时器初始化TL0=(65536-50000)%256;TH1=(65536-50000)/256;TL1=(65536-50000)%256;EA=1;ET0=1;ET1=1;TR0=1;
42、TR1=1;void timer0() interrupt 1/ 定时器 0 中断TH0=(65536-50000)/256;TL0=(65536-50000)%256;t0+;if(flag!=1)/flag不等于1时进行流水灯if(t0=10) t0=1; temp=_crol_(temp,1); P1=temp;else/否则进行灯闪烁if(t0%4=0) /小灯每200毫秒变化一次 P1=P1;if(t0=60) TR0=0;/3秒后关闭定时器 0,关闭灯,并置flag=1P1=0xff;flag1=1; void timer1() interrupt 3/ 定时器 1 中断函数TH1
43、=(65536-50000)/256;TL1=(65536-50000)%256;t1+;if(t1=2)(t1=0;shu-;bai=shu/100;shi=shu%100/10;ge=shu%10;if(shu=398)/当到398时把原来T0中的数清除,重新加裁初值让小灯闪烁(TR0=0;TH0=(65536-50000)/256;TL0=(65536-50000)%256;TR0=1;flag=1;t0=0;P1=0xff;TR1=0;void display(uchar aa,uchar bb,uchar cc,uchar bai,uchar shi,uchar ge) / 显示子函
44、数(dula=1;P0=tableaa;dula=0;P0=0xff;wela=1;P0=0xfe;wela=0;delay(1);dula=1;P0=tablebb;dula=0;P0=0xff;wela=1;P0=0xfd;wela=0;delay(1);dula=1;P0=tablecc;dula=0;P0=0xff;wela=1;P0=0xfb;wela=0;delay(1);dula=1;P0=tablebai;dula=0;P0=0xff;wela=1;P0=0xf7;wela=0;delay(1);dula=1;P0=tableshi;dula=0;P0=0xff;wela=1;
45、P0=0xef;wela=0;delay(1);dula=1;P0=tablege;dula=0;P0=0xff;wela=1;P0=0xdf;wela=0;delay(1);#include<reg52.h>#define uint unsigned int #define uchar unsigned char/*12864 液晶接 口定义 */ sbit rs= P2A5;sbit std = P2A6;sbit sclk = P2A7; sbit psb = P2A4; sbit rst = P2A2;sbit D1820 = P3A7; /*uchar code tab0
46、=" uchar code tab1=" uchar code tab2=" uchar code tab3=" uint i,j,s1num,num2;void delay(uint z) ( uint x,y;for(x=z;x>0;x-)for(y=110;y>0;y-);当前温度定义 18b20 总线 */ n.C”;n.n.void wr_date(uchar date)/ 写数据(uchar a,p;delay(10);a=date;rs=1;sclk=0;std=1;for(i=0;i<5;i+)(sclk=1;sclk=
47、0;std=0;sclk=1;sclk=0;std=1;/数据命令选择=1时读取数据/串口时钟,未开/选择串口方式开启字节/写/开启时钟脉冲/选择数据sclk=1;sclk=0;std=0;sclk=1;sclk=0;for(p=0;p<2;p+)(for(i=0;i<4;i+)(a=a<<1;左移目的是为了将溢出数据(即 0或1)赋予stdstd=CY;/单片机特殊功能寄存器,“ CY!于存放字符串溢出字符sclk=1;/ 一开一锁将数据显示sclk=0;std=0;for(i=0;i<4;i+)(sclk=1;sclk=0; void wr_com(uchar com) / 写命令(uchar a,p;delay(10);a=com;rs=1;/数据命令选择=1时读取数据sclk=0;/串口时钟,未开std=1;/选择串口方式for(i=0;i<5;i+)开启字节(sclk=1;sclk=0;std=0;sclk=1;开启时钟脉冲sclk=0;std=0;sclk=1;sclk=0;std=0;sclk=1;sclk=0;for(p=0;p<
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 基于区块链的审计轨迹完整性与可信度研究
- 基于可再生能源的农村地区集中式供暖解决方案
- 链家房产经纪人岗位的面试经验总结
- 双J管护理新进展与趋势
- 护理与医疗技术发展
- 安环主任职业规划方案
- 护理员护理伦理与案例分析
- 优势职业规划策略
- 护理带教核心技能培训
- 零售业项目策划与执行的面试指南
- 2025年医院党支部书记党建工作述职报告
- 大疆创新软件测试工程师晋升答辩含答案
- GB/T 46595-2025排水泵站一体化设备
- 幼儿园黄河介绍
- 内衣定制代加工合同
- 自救器课件培训课件
- 房建项目施工知识培训课件
- 黑马程序员合同模板(3篇)
- 2024年公共营养师之三级营养师真题及答案
- 医药ka专员培训课件
- 智能工厂总体架构及数字化应用解决方案
评论
0/150
提交评论