郭天祥十天学通单片机所有课后作业+答案.docx

上传人:b****4 文档编号:5372061 上传时间:2023-05-08 格式:DOCX 页数:44 大小:21.10KB
下载 相关 举报
郭天祥十天学通单片机所有课后作业+答案.docx_第1页
第1页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第2页
第2页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第3页
第3页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第4页
第4页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第5页
第5页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第6页
第6页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第7页
第7页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第8页
第8页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第9页
第9页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第10页
第10页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第11页
第11页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第12页
第12页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第13页
第13页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第14页
第14页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第15页
第15页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第16页
第16页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第17页
第17页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第18页
第18页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第19页
第19页 / 共44页
郭天祥十天学通单片机所有课后作业+答案.docx_第20页
第20页 / 共44页
亲,该文档总共44页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

郭天祥十天学通单片机所有课后作业+答案.docx

《郭天祥十天学通单片机所有课后作业+答案.docx》由会员分享,可在线阅读,更多相关《郭天祥十天学通单片机所有课后作业+答案.docx(44页珍藏版)》请在冰点文库上搜索。

郭天祥十天学通单片机所有课后作业+答案.docx

郭天祥十天学通单片机所有课后作业+答案

lesson1

对照TX-1C单片机学习板原理图写程序

用位操作和总线操作两种方法完成以下题目

1.熟练建立KEIL工程

2.点亮第一个发光管.

3.点亮最后一个发光管

4.点亮1、3、5、7

5.点亮二、四、五、六

6.尝试让第一个发光管闪烁

7.尝试设计出流水灯程序

======================================================================================================================

lesson2

第一个发光管以间隔200ms闪烁

8个发光管由上至下间隔1s流动,其中每个管亮500ms,灭500ms,亮时蜂鸣器响,灭时关闭蜂鸣器,一直重复下去。

8个发光管来回流动,第个管亮100ms,流动时让蜂鸣器发出“滴滴”声。

用8个发光管演示出8位二进制数累加过程。

8个发光管间隔200ms由上至下,再由下至上,再重复一次,然后全部熄灭再以300ms间隔全部闪烁5次。

重复此过程。

间隔300ms第一次一个管亮流动一次,第二次两个管亮流动,依次到8个管亮,然后重复整个过程。

间隔300ms先奇数亮再偶数亮,循环三次;一个灯上下循环三次;两个分别从两边往中间流动三次;再从中间往两边流动三次;8个全部闪烁3次;关闭发光管,程序停止。

======================================================================================================================

lesson3

1、利用定时/计数器T0从输出周期为1s的方波,让发光二极管以1HZ闪烁,设晶振频率为12MHz。

2、利用定时/计数器T1产生定时时钟,由P1口控制8个发光二极管,使8个指示灯依次一个一个闪动,闪动频率为10次/秒(8个灯依次亮一遍为一个周期),循环。

3、同时用两个定时器控制蜂鸣器发声,定时器0控制频率,定时器1控制同个频率持续的时间,间隔300ms依次输出1,10,50,100,200,400,800,

1k(hz)的方波。

4、用定时器以间隔500MS在6位数码管上依次显示0、1、2、3….C、D、E、F,重复。

lesson4

1.利用动态扫描方法在六位数码管上显示出稳定的654321.

2.用动态扫描方法和定时器1在数码管的前三位显示出秒表,精确到1%秒,即后两位显示1%秒,一直循环下去。

3.利用动态扫描和定时器1在数码管上显示出从765432开始以1/10秒的速度往下递减直至765398并保持显示此数,与此同时利用定时器0以500MS速度进行流水灯从上至下移动,当数码管上数减到停止时,实验板上流水灯也停止然后全部开始闪烁,3秒后(用T0定时)流水灯全部关闭、数码管上显示出“HELLO”。

到此保持住。

lesson5

数码管前三位显示一个跑表,从000到999之间以1%秒速度运行,当按下一个独立键盘时跑表停止,松开手后跑表继续运行。

(用定时器设计表)。

在上题的基础上,用另外三个独立键盘实现按下第一个时计时停止,按下第二个时计时开始,按下第三个是计数值清零从头开始。

按下16个矩阵键盘依次在数码管上显示1-16的平方。

如按下第一个显示1,第二个显示4...

 

======================================================================================================================

lesson7

1.由上位机发送1给单片机时,蜂鸣器以400ms频率发声,发2时以200ms频率发声,发3时以100ms频率发声,发4时关闲蜂鸣器。

1.以2400bps从计算机发送任一字节数据,当单片机收到该数据后,在此数据前加上一序号然后连同此数据一起发送至计算机,当序号超过255时归零。

2.以16进制发送一个0-65536之间的任一数,当单片机收到后在数码管上动态显示出来,波特率自定。

3.用AD以1HZ的频率采集模拟信号,然后转换成数字量,再将其以1200bps发送到计算机,在计算机上显示。

4.按下矩阵键盘第一行时以1200bps发送,1,2,3,4,第二行时以2400bps发送5,6,7,8,第三行以4800bps发送,9,10,11,12,第四行以9600pbs发送,13,14,15,16.

======================================================================================================================

Lesson1作业

1用位操作点亮第一个发光管.

程序看不懂没关系,后面章节会有详细讲解)

{uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain(){uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain()..C、D、E、F,重复。

设时钟频率为12M

*/

/*********************************************************/

#include<>时钟频率为

*/

/*********************************************************/

#include<>//52单片机头文件

#include<>//包含有左右循环移位子函数的库

#defineuintunsignedint//宏定义

#defineucharunsignedchar//宏定义

sbitdula=P2^6;//数码管段选锁存端

sbitwela=P2^7;////数码管位选锁存端

ucharcodetable[]={//数码管显示编码

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};

voiddisplay(uchar,uchar,uchar,uchar,uchar,uchar);//函数声明

voiddelay(uint);

voidmain()

{

while

(1)

{

display(6,5,4,3,2,1);//始终显示

}

}

voiddisplay(ucharone,uchartwo,ucharthree,ucharfour,ucharfive,ucharsix)

{

dula=1;

P0=table[one];//送段数据

dula=0;

P0=0xff;//送位数据前关闭所有显示,防止打开位选锁存后段选数据通过位选锁存器

wela=1;

P0=0xfe;

wela=0;

delay

(1);

dula=1;

P0=table[two];

dula=0;

P0=0xff;

wela=1;

P0=0xfd;

wela=0;

delay

(1);

dula=1;

P0=table[three];

dula=0;

P0=0xff;

wela=1;

P0=0xfb;

wela=0;

delay

(1);

dula=1;

P0=table[four];

dula=0;

P0=0xff;

wela=1;

P0=0xf7;

wela=0;

delay

(1);

dula=1;

P0=table[five];

dula=0;

P0=0xff;

wela=1;

P0=0xef;

wela=0;

delay

(1);

dula=1;

P0=table[six];

dula=0;

P0=0xff;

wela=1;

P0=0xdf;

wela=0;

delay

(1);

}

voiddelay(uintz)//延时子函数

{

uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

2/*

用动态扫描方法和定时器1在数码管的前三位显示出秒表,

精确到1%秒,即最后一位显示1%秒,一直循环下去

设时钟频率为12M

*/

/*********************************************************/

#include<>//52单片机头文件

#include<>//包含有左右循环移位子函数的库

#defineuintunsignedint//宏定义

#defineucharunsignedchar//宏定义

sbitdula=P2^6;//数码管段选锁存端

sbitwela=P2^7;////数码管位选锁存端

ucharge,shi,bai;

uinttt;

ucharcodetable[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};

voiddisplay(uchar,uchar,uchar);//函数声明

voiddelay(uint);

voidmain()

{

TMOD=0x10;//设置定时器1为工作方式1

TH1=(65536-10000)/256;

TL1=(65536-10000)%256;

EA=1;//开总中断

ET1=1;//开定时器1中断

TR1=1;//启动定时器1

while

(1)

{

display(bai,shi,ge);

}

}

 

voidexter0()interrupt3//定时器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;

}

voiddisplay(ucharone,uchartwo,ucharthree)

{

dula=1;

P0=table[one];//送段数据

dula=0;

P0=0xff;//送位数据前关闭所有显示,防止打开位选锁存后段选数据通过位选锁存器

wela=1;

P0=0xfe;

wela=0;

delay

(1);

dula=1;

P0=table[two];

dula=0;

P0=0xff;

wela=1;

P0=0xfd;

wela=0;

delay

(1);

dula=1;

P0=table[three];

dula=0;

P0=0xff;

wela=1;

P0=0xfb;

wela=0;

delay

(1);

}

voiddelay(uintz)//延时子函数

{

uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

3/*

利用动态扫描和定时器1在数码管上显示

出从765432开始以1/10秒的速度往下递减

直至765398并保持显示此数,与此同时利

用定时器0以500MS速度进行流水灯从上至

下移动,当数码管上数减到停止时,实验

板上流水灯也停止然后全部开始闪烁,3秒

后(用T0定时)流水灯全部关闭、数码管上

显示出"HELLO"。

到此保持住。

设晶振频率为12MHz。

*/

/*********************************************************/

#include<>//52单片机头文件

#include<>//包含有左右循环移位子函数的库

#defineuintunsignedint//宏定义

#defineucharunsignedchar//宏定义

sbitdula=P2^6;

sbitwela=P2^7;

ucharcodetable[]={//显示数据编码

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71,

0x76,0x79,0x38,0x3f,0};

uchartemp,t0,t1,bai,shi,ge,flag,flag1;

uintshu;

voidinit();//函数声明

voiddisplay(ucharaa,ucharbb,ucharcc,ucharbai,ucharshi,ucharge);

voiddelay(uintz)//延时子函数

{

uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain()//主函数

{

init();

while

(1)

{

if(flag1!

=1)//如果flagi不再等于1则显示数据

display(7,6,5,bai,shi,ge);

else

display(16,17,18,18,19,20);//否则显示hello

}

}

voidinit()//初始化函数

{

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;

TR1=1;

}

voidtimer0()interrupt1//定时器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=1

P1=0xff;

flag1=1;

}

}

}

voidtimer1()interrupt3//定时器1中断函数

{

TH1=(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;

}

}

}

voiddisplay(ucharaa,ucharbb,ucharcc,ucharbai,ucharshi,ucharge)//显示子函数

{

dula=1;

P0=table[aa];

dula=0;

P0=0xff;

wela=1;

P0=0xfe;

wela=0;

delay

(1);

dula=1;

P0=table[bb];

dula=0;

P0=0xff;

wela=1;

P0=0xfd;

wela=0;

delay

(1);

dula=1;

P0=table[cc];

dula=0;

P0=0xff;

wela=1;

P0=0xfb;

wela=0;

delay

(1);

dula=1;

P0=table[bai];

dula=0;

P0=0xff;

wela=1;

P0=0xf7;

wela=0;

delay

(1);

dula=1;

P0=table[shi];

dula=0;

P0=0xff;

wela=1;

P0=0xef;

wela=0;

delay

(1);

dula=1;

P0=table[ge];

dula=0;

P0=0xff;

wela=1;

P0=0xdf;

wela=0;

delay

(1);

}

#include<>

#include<>

#defineuintunsignedint

#defineucharunsignedchar

sbitdula=P2^6;

sbitwela=P2^7;

sbits2=P3^4;

ucharcodetable[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71,

0x76,0x79,0x38,0x3f,0};

ucharflag,t0,ge,shi,bai;

uintshu;

voidinit();

voiddisplay(ucharaa,ucharbb,ucharcc);

voiddelay(uintz)

{

uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain()

{

init();

while

(1)

{

display(bai,shi,ge);

if(s2==0)

{

delay(10);

if(s2==0)

{

TR0=0;

while(!

s2)

display(bai,shi,ge);

TR0=1;

}

}

}

}

voidinit()

{

TMOD=0x01;

TH0=(65536-10000)/256;

TL0=(65536-10000)%256;

EA=1;

ET0=1;

TR0=1;

}

voidtimer0()interrupt1

{

TH0=(65536-10000)/256;

TL0=(65536-10000)%256;

shu++;

if(shu==1000)

shu=0;

bai=shu/100;

shi=shu%100/10;

ge=shu%10;

}

 

voiddisplay(ucharaa,ucharbb,ucharcc)

{

dula=1;

P0=table[aa];

dula=0;

P0=0xff;

wela=1;

P0=0xfe;

wela=0;

delay

(1);

dula=1;

P0=table[bb];

dula=0;

P0=0xff;

wela=1;

P0=0xfd;

wela=0;

delay

(1);

dula=1;

P0=table[cc];

dula=0;

P0=0xff;

wela=1;

P0=0xfb;

wela=0;

delay

(1);

}

#include<>

#include<>

#defineuintunsignedint

#defineucharunsignedchar

sbitdula=P2^6;

sbitwela=P2^7;

sbits2=P3^4;

sbits3=P3^5;

sbits4=P3^6;

sbits5=P3^7;

ucharcodetable[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71,

0x76,0x79,0x38,0x3f,0};

ucharflag,t0,ge,shi,bai;

uintshu;

voidinit();

voiddisplay(ucharaa,ucharbb,ucharcc);

voiddelay(uintz)

{

uintx,y;

for(x=z;x>0;x--)

for(y=110;y>0;y--);

}

voidmain()

{

init();

while

(1)

{

display(bai,shi,ge);

if(s2==0)

{

delay(10);

if(s2==0)

{

TR0=0;

while

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

当前位置:首页 > 经管营销 > 经济市场

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2