- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
单片机实验汇总
实验二
(1)8个流水灯从下往上依次点亮
#include reg52.h //将这个文件中的全部内容放到引用文件的位置处
#include intrins.h // 包含字符循环移位指令_crol_等时使用的函数头文件
void delay500ms(void)
{
unsigned char i,j,k;
for(i=15;i0;i--)
for(j=202;j0;j--)
for(k=81;k0;k--); //延时函数
}
void main (void) //前面一个void表示没有返回值,后面void表示不带任何参数
{
unsigned int temp; //定义一个 无符号的整型变量
temp=0xfe; //通过改变这个值可以使led开始状态改变
while (1)
{
P1=temp; //P1口赋初值,把temp的值赋给P1口
delay500ms();
temp = _cror_(temp,1);//右移函数 ,从下往上移动,使用_crol_(temp,1)左移,(从上往下移动),改变“1”的值可改变移动几位
}}
(2)流水灯下移,按键P30按下下移“一次”
#includereg52.h
#includeintrins.h //双引号表示编译器先进入当前工程所在文件夹处开始搜索该头文件。
#define uchar unsigned char //宏定义,意思就是说以后见到uchar就表示unsigned char(无符号字符型)
#define uint unsigned int
sbit key=P3^0; //位定义,意思用到那一个I/O口要先说明一下。
void delay(uint t)
{uint i,j;
for(i=0;it;i++)//调用时,通过改变t的值可以得到自己想要的延时时间
for(j=0;j100;j++);
}
void main()
{
uchar temp=0xFE;
while(1)
{P1=temp;
if(key==0)//判断按键是否按下,按下时为0电平
{delay(15);//防抖动,有按键时一定要加这个延时
if(key==0) //再次判断按键是否按下
{
while(!key);// 等待按键释放,“每次”按键按下为0时,取反为1,接着执行while循环后面的类容,如果一直按着就会一直循环往下流水。
temp=_crol_(temp,1); //循环函数。可以改为右移(往上) temp=_cror_(temp,1)
}
}}}
(3)按键按下一直循环移动
#includeAT89X51.H
#includeintrins.h
#define uchar unsigned char
#define uint unsigned int
sbit key=P3^0;
void delay(uint t)
{uint i,j;
for(i=0;it;i++)
for(j=0;j200;j++);
}
void main()
{ unsigned int temp ,x;
P1=0xfe; //给P1口赋初值,开始显示的值
if(key==0)
{
delay(20);
while(1)
{
temp=0xfe;//一定要给temp赋值,不然默认为0.
for(x=0;x8;x++) //实现8个灯流水,不加这句也行,把temp=0xfe放在while(1)外面,为了节约系统资源
{
P1=temp; //每次左移一位后赋初值给P1口
temp=_crol_(temp,1);// 右移(往上)改为temp=_cror_(temp,1);
delay(500);
}
}
}
}
(4)按键按下一直循环左移一次然后右移一次
#includeAT89X51.H
#includeintrins.h
#define uchar unsigned char
#define uint unsigned int
sbit key=P3^0;
void delay(uint t)
{uint i,j;
for(i=0;it;i++)
for(j=0;j200;j++);
}
void main()
{
您可能关注的文档
- T100版型介紹.pptx
- T100程式設計流程.ppt
- the_croods_疯狂原始人__克鲁德一家_古鲁一家.ppt
- Tomcat架构与实现分析.ppt
- tong游社答辩最终版3.ppt
- UG90全套视频教程地址.doc
- Win10如何取消“无法验证发布者”提示的解决方法.doc
- Word初级学习4设置字体格式.ppt
- windows10系统安装过程.pptx
- U8:企业一体化信息安全解决方案.pptx
- 2024年江西省高考政治试卷真题(含答案逐题解析).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)物理试卷(含答案详解).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)地理试卷(含答案详解).pdf
- 2024年内蒙通辽市中考化学试卷(含答案逐题解析).docx
- 2024年四川省攀枝花市中考化学试卷真题(含答案详解).docx
- (一模)长春市2025届高三质量监测(一)化学试卷(含答案).pdf
- 2024年安徽省高考政治试卷(含答案逐题解析).pdf
- (一模)长春市2025届高三质量监测(一)生物试卷(含答案).pdf
- 2024年湖南省高考政治试卷真题(含答案逐题解析).docx
- 2024年安徽省高考政治试卷(含答案逐题解析).docx
文档评论(0)