51单片机实验报告范文Word格式.docx

上传人:b****5 文档编号:19102263 上传时间:2023-01-03 格式:DOCX 页数:26 大小:25.16KB
下载 相关 举报
51单片机实验报告范文Word格式.docx_第1页
第1页 / 共26页
51单片机实验报告范文Word格式.docx_第2页
第2页 / 共26页
51单片机实验报告范文Word格式.docx_第3页
第3页 / 共26页
51单片机实验报告范文Word格式.docx_第4页
第4页 / 共26页
51单片机实验报告范文Word格式.docx_第5页
第5页 / 共26页
点击查看更多>>
下载资源
资源描述

51单片机实验报告范文Word格式.docx

《51单片机实验报告范文Word格式.docx》由会员分享,可在线阅读,更多相关《51单片机实验报告范文Word格式.docx(26页珍藏版)》请在冰豆网上搜索。

51单片机实验报告范文Word格式.docx

unsignedchara,b;

for(;

c>0;

c-—)

)—-b;

0〉b;

83=b(rofﻩ{ﻩﻩﻩ

)--a;

0>

a;

031=a(rofﻩ

}ﻩ

}ﻩ}实验原理

这里运用了C语言中得位运算符,,位运算符左移,,初始值得二进制为11111110,之后左移一次变成111111000,当变成0000

00000时通过fif语句重置1111111110、延迟函数在第一个报告已经说出了,不再多说..

实验3流水灯(库函数版)实验现象

最开始还就是最右边得一个不亮,然后不亮得灯转移到最右边得第二个,此时第一个恢复亮度,这样依次循环.实验代码#include〈reg51、h>

#include〈intrins、h〉voidDelay10ms(unsignedintc);

voidmain(void){

unsignedcharLED;

EFx0=DELﻩ

)1(elihwﻩ{ﻩ

P0=LED;

)05(sm01yaleDﻩﻩ

)1,DEL(_lorc_=DELﻩ}ﻩ}voidDelay10ms(unsignedintc){

unsignedchara,b;

c〉0;

c——)

for(b=38;

b〉0;

b—-)

{ﻩﻩ

)-—a;

0〉a;

031=a(rofﻩ

}ﻩ}}实验原理

利用头文件中得函数,_crol_(,,

),可以比位操作符更方便得进行22进制得移位操作,,比位操作符优越得就是,该函数空位补全时都就是用那个移位移除得数据,,由此比前一个例子不需要fif语句重置操作..

数码管实验

实验现象单个数码管按顺序显示0-9与A-F。

#includevoidmain(void){

0=irahcdengisnuﻩwhile

(1)

{ﻩ

P0=~DIG_CODE[i];

++iﻩ

)61==i(fiﻩ

0=iﻩ}ﻩ

)05(sm01yaleDﻩ}

ﻩ}voidDelay10ms(unsignedintc)

//Î

ó

²

î

0us

unsignedchara,b;

for(;

c—-)

for(b=38;

b〉0;

b--)

{

)—-a;

0〉a;

031=a(rofﻩ

}ﻩ}

}实验原理

根据数码管得点亮原理,依次找到代表00-9,A--FF得位码,用循环与延迟函数就可以达到要求了。

实验动态数码管#include〈reg51、h>#defineGPIO_DIG

P0ﻩ#defineGPIO_PLACEP1

unsignedcharcodeDIG_PLACE[8]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};

unsignedcharcodeDIG_CODE[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

unsignedcharDisplayData[8];

voidDigDisplay();

voidmain(void)

unsignedchari;

for(i=0;

i<8;

i++)

DisplayData[i]=DIG_CODE[i];

}ﻩwhile

(1)

)(yalpsiDgiDﻩ}

ﻩﻩ}voidDigDisplay()

irahcdengisnuﻩ

jtnidengisnuﻩfor(i=0;

i<

8;

i++)

]i[ECALP_GID=ECALP_OIPGﻩﻩ

]i[ataDyalpsiD=GID_OIPGﻩ

01=jﻩﻩﻩ

ﻩwhile(j—-);

};

00x0=GID_OIPGﻩﻩ}实验原理

依然找到相应数字与字母得编码,,由于必须通过快速扫描利用视觉暂留来实现数码管得显示,,分段码与位码,不断扫描。

最后如果更换数字得话,,需要消隐操作,防止数码管重复显示所带来得不清楚..

实验外部中断实验现象

每按一下独立按键,就会在数码管显示屏上+1.#include〈reg51、h〉#includesbitLS138A=P2^2;

sbitLS138B=P2^3;

sbitLS138C=P2^4;

unsignedintLedNumVal_1,LedNumVal_2,LedOut[8];

UnsignedcharcodeDisp_Tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40};

voiddelay(unsignedinti)

charj;

for(i;

i>0;

i--)

for(j=200;

j>0;

j—-);

}voidmain(void)

unsignedchari;

P0=0xff;

P1=0xff;

P2=0xff;

IT0=1;

EX0=1;

IT1=1;

EX1=1;

EA=1;

while

(1)

LedOut[0]=Disp_Tab[LedNumVal_1%10000/1000];

LedOut[1]=Disp_Tab[LedNumVal_1%1000/100]|0x80;

LedOut[2]=Disp_Tab[LedNumVal_1%100/10];

LedOut[3]=Disp_Tab[LedNumVal_1%10];

]0001/00001%2_laVmuNdeL[baT_psiD=]4[tuOdeLﻩ

LedOut[5]=Disp_Tab[LedNumVal_2%1000/100];

LedOut[6]=Disp_Tab[LedNumVal_2%100/10];

LedOut[7]=Disp_Tab[LedNumVal_2%10];

for(i=0;

i<

i++)

]i[tuOdeL=0Pﻩ

switch(i)ﻩ

ﻩcase0:

LS138A=0;

LS138B=0;

LS138C=0;

break;

case1:

LS138A=1;

LS138B=0;

LS138C=0;

break;

case2:

LS138A=0;

LS138B=1;

LS138C=0;

break;

case3:

LS138A=1;

LS138B=1;

LS138C=0;

break;

case4:

LS138A=0;

LS138B=0;

LS138C=1;

break;

case5:

LS138A=1;

LS138B=0;

LS138C=1;

break;

case6:

LS138A=0;

LS138B=1;

LS138C=1;

case7:

LS138A=1;

LS138B=1;

LS138C=1;

break;

}

)051(yaledﻩ}ﻩ

}}void

counter0(void)interrupt0

using1{

EX0=0;

LedNumVal_1++;

EX0=1;

}void

counter1(void)interrupt2using2{

EX1=0;

LedNumVal_2++;

EX1=1;

}实验原理对于数码管得显示采用138译码器,通过switch语句与数字一一对应,通过P3、2P3、3外部中断接口使数码管成功计数。

外部中断函数为INT0与INT1。

实验一:

开发环境的搭建

一、

(1)、keil的安装与破解

点击Keil安装包,一键傻瓜式操作,安装完成后以管理员身份打开Keil,在File里选择licensemanagement把CID复制到注册机里的CID栏,注册机里的Target选择C51,然后点击Generate,将生成的激活码复制到licensemanagement里的LIC栏,并点击AddLIC,即完成破解。

(2)、CH340驱动安装

1(3)、普中烧录软件的使用

波特率选择9600,速度选择低速,文件路径选择HEX文件的路径

(4)、keil的使用

2

新建工程并保存,在CPU里面选择STC90C52RC,再新建C文件,注意保存时手动加上.c后缀,再在SourceGroup1右击选择AddFilestoGroup"

SourceGroup1"

找到刚才新建的C文件,然后找到

图标并点击,再Target里将晶振频率改为12MHz,将Output里生成HEX文件的勾打上即可生成HEX文件。

3(5)、protues的安装与破解

破解时以管理员身份运行破解软件,目标文件里找到安装的路径,再点击升级,即可完成破解。

4

(6)、protues的使用

双击蓝色ISIS图标即可打开Proteus,File里新建并保存,然后点击“P”即可选择自己所需元器件,输入AT89C52单片机,确定后在图纸中点击即可,双击单片机将对话框中的ProgramFile选择Keil生成的HEX文件,电路及程序都完成后,点击左下角即可开始仿真,点击

停止仿真。

5二、实验结论

在实验一里学会了开发环境的搭建,学会并熟练了KeiluVision4和Proteus7.8以及普中烧录软件的使用,基本实现了用Keil编写程序并且生成HEX文件,能够用Proteus画基本仿真图并且成功实现仿真,在仿真过程中出现了win10电脑不能正常实现仿真的问题,在经过XX等多方面查找之后找到了如下解决办法:

1、路径上不能有中文

2、仿真时出现cannotopen"

C:

User\\?

\\AppData\\Local\\Temp\\LISA5476.SDF"

的错误时:

右击

我的电脑-属性-高级系统设置-环境变量,在“用户变量”栏里找到TEMP与TMP,分别双击,将变量值都改为%SystemRoot%\\TEMP

如果还不行将下面的“系统变量”栏里的TEMP与TMP同样修改方法,如果没有新建就行。

(部分电脑还不行需要重启)

6

实验二:

如何点亮一个发光二极管

一、实验原理

发光二极管采用的是共阳极接法,低电平点亮,高电平熄灭。

二、硬件电路图

采用共阳极接线法,即一端LED负极接单片机,正极通过一个1KΩ限流电阻接到+5V,单片机给低电平点亮,高电平熄灭。

三、程序代码

(1)位操作法#include//包含51系列单片机头文件sbitled1=P2^0;

//特殊功能位声明

voidmain()

//主函数

无返回值,无参数{

先写包含51系列单片机头文件,再用sbit位定义声明使用的P2.0I/O口,在主函数里给LED1一个低电平,即LED1=0,灯亮,在结束时写一个while

(1)停止程序。

(2)总线法

#include//包含51系列单片机头文件voidmain()

//主函数无返回值,无参数

7led1=0;

//亮灯while

(1);

//程序停止{

先写包含51系列单片机头文件,直接写一个无返回值、无参数的主函数,即voidmain(),在主函数里把01010101以十六进制形式即0x55赋给P2口,达到间隔点亮的效果,最后仍然要写一个while

(1)停止程序。

四、实验结论P2=0x55;

while

(1);

//间隔点亮01010101//程序停止

在实验二学习到了单片机用两种不同的操作方式点亮单个或者多个LED,学会了单片机与LED的连接方式,知道了一个程序应该有头有尾,在程序结束的时候要加一个while

(1),让我在以前的知识上得到了补充学习。

8

实验三:

控制LED的亮灭

LED的亮灭过程可以看成“LED亮过一段时间LED灭过一段时间”如此反复,所以此次实验重点在“过一段时间”这个问题上。

采用8个LED灯,用过限流电阻以共阳极接法接在P2口上

三、程序代码

#include//包含51系列单片机头文件

#defineuintunsignedint

//宏定义

把unsignedint重命名为uint#defineucharunsignedcharvoidDelay(uintz){

//延时z是个形式参数

uintx,y;

for(x=z;

x>

x--)

//外部的循环

for(y=110;

y>

y--);

//内部的循环

P2=0xff;

//把P2口清零

9

}//大循环,始终执行括号里的内容

P2=0x55;

Delay(500);

P2=0xaa;

//间隔闪烁

0101010

1//间隔闪烁

10101010

采用宏定义把unsignedint重命名为uint,把unsignedchar重命名为uchar,写一个带有形式参数的函数作为解决“过一段时间”这个问题的延时函数,函数里采用两个for语句嵌套的方式来延时,也可使用while语句,主函数里先将I/O口清零,然后用一个死循环whlie

(1),把要执行的内容放在死循环里始终重复执行,具体执行的内容是间隔闪烁,即01010101和10101010,分别以十六进制形式先后赋给P2口并调用延时函数Delay(),在调用Delay()函数时给一个需要延时的时间长度,即500,表示延时500个单位时间。

四、实验结论

实验三学会了延时函数的使用,知道了如何让LED实现闪烁,但是我认为延时函数可能是空耗CPU,因为延时这段时间CPU什么都没有做,只是等着,所以我认为降低了CPU的效率。

10

实验四:

流水灯

流水灯即LED从一端依次亮、灭流向另外一端,有很多方法,着重采用位移操作法和库操作法。

采用8个LED灯,用过限流电阻以共阳极接法接在P2口上三、程序代码

(1)位移操作法#include#defineuintunsignedint#defineucharunsignedchar

voiddelay(uintz)//延时函数{

11uintx,y;

x--)for(y=110;

位移操作符为:

>

,本次采用左移方式将11111110的各二进制位全部左移8位,由于取反其右边空出的位用1填补,高位左移溢出则舍弃该高位。

(2)库操作法#include#include#defineuintunsignedint#defineucharunsignedchar

voidmain(){

uchari;

i=0x7f;

ucharj;

while

(1){

}P2=~(1

//位移操作法

12

}}P2=i;

delay(500);

i=_cror_(i,1);

//库操作法

库操作法注意包含intrins.h文件,以便调用_cror_(),i作为一个常数,是流水灯的起始位置,同时也是被操作的数据,1表示循环右移的次数,_cror_()是右移函数,_crol_()是左移函数四、实验结论

实验四学会了两种高效率的流水灯方式,其中更倾向于库函数操作法,但是要一定要记得包含intrins.h文件。

13

实验五:

数码管的显示

静态显示:

采用一个I/O口控制数码管,就像控制8个LED灯一样的控制方法。

动态显示:

用两个I/O口控制数码管的段选、位选,动态扫描显示是通过分时轮流控制各个数码管的COM端,就使各个数码管轮流受控显示。

在轮流显示过程中,每位数码管的点亮时间为1~2ms,由于人的视觉暂留现象及发光二极管的余辉效应,尽管实际上各位数码管并非同时点亮,但只要扫描的速度足够快,给人的印象就是一组稳定的显示数据,不会有闪烁感,动态显示的效果和静态显示是一样的,能够节省大量的I/O端口,而且功耗更低。

14静态显示采用共阳极数码管,即给低电平亮,对单个数码管来说可以直接和单片机I/O连接,八段按顺序dp-g-f-e-d-c-b-a,和点亮LED的方法相同,看需要的字符是让那几个LED亮就为0,最后得出字符码。

动态显示是用两个I/O口控制数码管的段选、位选,动态扫描显示是通过分时轮流控制各个数码管的COM端,就使各个数码管轮流受控显示。

静态显示#include#defineuintunsignedint#defineucharunsignedchar

uchartable={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};

//0~9数字voidmain(){

用一个数组将0-9的显示段码放在一起,在主函数调用的时候直接给[]里写需要现实的数字,即可显示相应的数字

0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90是共阳极数码管0-9的显示码

3

5

7

15while

(1){

}P2=table[7];

//调用数组里的第7个动态显示

#include#defineuintunsignedint#defineucharunsignedchar

ucharsmg_wei={0x20,0x10,0x08,0x04,0x02,0x01};

//位选,第0~5位,最右端为第0位

ucharsmg_duan={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf};

//段选0~9

//

voidDelay(uintz)

//延时z是个形式参数{

}for(y=110;

voidsmg(uintwi,du)

//数码管函数{

P1=smg_wei[wi];

//调用数码管的位选数组P2=smg_duan[du];

Delay

(1);

//调用数码管的段选数组//延时稳定一下

P1=P2=0xff;

//P1、P2口初始化while

(1){

smg(0,5);

smg(1,4);

smg(2,3);

smg(3,2);

//第0位显示5//第1位显示4//第2位显示3//第3位显示2

16

smg(4,1);

smg(5,0);

//第4位显示1//第5位显示0

试验成功!

17

实验六:

蜂鸣器

一、实验原理无源蜂鸣器,输入波形会响。

单片机通过P2.7口直接连接无源蜂鸣器sounder,蜂鸣器另一端接地。

sbitfmq=P2^7;

//位定义蜂鸣器

uinti;

fmq=1;

for(i=0;

i

18//初始化

}}fmq=~fmq;

//无源蜂鸣器需要给定波形才会响

因为采用的是无源蜂鸣器,内部没有振荡器所以需要通过fmq=~fmq;

给一个高低电平波形让蜂鸣器响,用一个for语句,并且把for语句放在while

(1)大循环下面让蜂鸣器一直按固定的频率响。

实验成功!

19

实验七:

独立按键

由单片机作为主控,蜂鸣器及周围电路作为输出设备,按键作为输入设备,实现按键按下去蜂鸣器响。

蜂鸣器外接一个三极管放大电路三、程序代码

sbitkey=P2^0;

20voidbutton(){

按键的调用函数,判断按键是否按下,第一次判断按下之后延时消抖再次判断按键是否按下,如果是按下了执行里面相应的内容,执行完之后进行一个松手检测,判断是否松手。

在主函数的大循环之前将按键置为1,避免误读。

四、实验结论fmq=1;

key=1;

//蜂鸣器赋初值不响//按键写1,避免误读}

if(key==0)

Delay(20);

fmq=0;

//蜂鸣器响

//消抖

while(!

key);

//松手检测

//大循环{

}button();

//调用按键函数

21

22

实验八:

继电器

二、实验原理

以单片机为主控,按键为输入设备,控制继电器的的开和关二、硬件电路图

按键的一端接地,另一端接单片机的I/O口

三、程序代码#include#defineuintunsignedint#defineucharunsignedchar

sbitjdq=P2^0;

sbitkey=P2^7;

voidaj()

23{

继电器的程序较为简单,只需要置0或者置1即可。

五、实验结论jdq=0;

}jdq=~jdq;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 简历

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1