#+
单片机原理及应用(C语言版)
思考题与习题答案
第1章 单片机概述
1.什么是单片机?
答:将中央处理器(Central Processing Unit,CPU)、随机存储器、只读存储器、中断系统、定时器/计数器以及I/O接口电路等微型计算机的主要部件集成在一块芯片上,使其具有计算机的基本功能,就叫做单片微型计算机(Single Chip Micro Computer,SCMC),简称单片机。由于单片机的指令功能是按照工业控制的要求设计,所以单片机又称为微控制器(Micro Controller Unit,MCU)。
2.单片机有哪些特点?
答: (1)单片机的存储器ROM和RAM是严格区分的。ROM称为程序存储器,只存放程序、固定常数及数据表格。RAM则为数据存储器,用作工作区及存放用户数据。
(2)采用面向控制的指令系统。
(3)单片机的I/O引脚通常是多功能的。
(4)单片机的外部扩展能力强。
(5)单片机体积小,成本低,运用灵活,易于产品化。
(6)面向控制,能有针对性地解决从简单到复杂的各类控制任务,因而能获得最佳的性能价格比。
(7)抗干扰能力强,适用温度范围宽。
(8)可以方便地实现多机和分布式控制,使整个控制系统的效率和可靠性大为提高。
3.单片机的应用有哪些?
答: (1)工业控制。单片机可以构成各种工业控制系统、数据采集系统等。如数控机床、自动生产线控制、电机控制、测控系统等。
(2)仪器仪表。如智能仪表、医疗器械、数字示波器等。
(3)计算机外部设备与智能接口。如图形终端机、传真机、复印机、打印机、绘图仪、磁盘/磁带机、智能终端机等。
(4)商用产品。如自动售货机、电子收款机、电子秤等。
(5)家用电器。如微波炉、电视机、空调、洗衣机、录像机、音响设备等。
(6)消费类电子产品。
(7)通讯设备和网络设备。
(8)儿童智能玩具。
(9)汽车、建筑机械、飞机等大型机械设备。
(10)智能楼宇设备。
(11)交通控制设备。
4.常见的单片机有哪些类型?
答: 1.AVR单片机;2.Motorola单片机;3.MicroChip单片机;
4.Scenix单片机;5.EPSON单片机;7.GMS90单片机;8.华邦单片机
9.Zilog单片机;10.NS单片机;11.AX1001单片机
第2章 MCS-51单片机结构与原理
1.MCS-51单片机内部包含哪些主要逻辑功能部件?
答:(1)1个8位的微处理器CPU。
(2)8KB的片内程序存储器Flash ROM(51子系列的Flash ROM为4KB),用于烧录运行的程序、常数数据。
(3)256B的片内数据存储器RAM(51子系列的RAM为128B),在程序运行时可以随时写入数据和读出,用于存放函数相互传递的数据、接收的外部数据、中间结果、最后结果以及显示的数据等。
(4)3个16位的定时器/计数器(51子系列仅有2个定时器),每个定时器/计数器可以设置为计数方式,用于对外部事件信号进行计数,也可以设置为定时方式,满足各种定时要求。
(5)有一个管理6个中断源(51子系列1是5个中断源)、两个优先级的中断控制器。
(6)4个8位并行I/O端,每个端口既可以用作输入,也可以用于输出。
(7)一个全双工的UART(通用异步接收发送器)串行I/O口,用于单片机之间的串行通信,或者单片机与PC机、其它设备、其它芯片之间的串行通信。
(8)片内振荡电路和时钟发生器,只需外面接上一晶振或输入振荡信号就可产生单片机所需要的各种时钟信号。
(9)有一个可寻址64KB外部数据存储器、还可以寻址64KB外部程序存储器的三总线的控制电路。
2.MCS-51单片机的引脚有何功能?信号为何种电平?
答: 为片外程序存储器选择输入端。该引脚为低电平时,使用片外程序存储器,为高电平时,使用片内程序存储器。
3.MCS-51单片机的ALE引脚有何功能?信号波形是什么?
答: ALE为地址锁存信号,每个机器周期输出两个正脉冲。在访问片外存储器时,下降沿用于控制外接的地址锁存器锁存从P0口输出的低8位地址。在没有接外部存储器时,可以将该引脚的输出作为时钟信号使用。
4.MCS-51单片机的存储器分为哪几个空间?如何区分不同空间的寻址?
答: MCS-51单片机有4个存储空间,它们是片内程序存储器和数据存储器,在片外可以扩展的程序存储器和数据存储器。这4个存储空间可以分成三类:片内数据存储空间(256B的RAM和128B的特殊功能寄存器)、片外数据存储空间(64KB)、片内和片外统一编址的程序存储空间(64KB)。不同的存储空间,它们有各自的寻址方式和访问指令。片内数据存储空间用MOV指令访问。片外数据存储空间用MOVX指令访问。片内和片外统一编址的程序存储空间用MOVC指令访问。
5.简述MCS-51单片机片内RAM的空间分配。内部RAM低128字节分为哪几个主要部分?各部分主要功能是什么?
答: 片内数据存储器按照寻址方式,可以分为三个部分:低128字节数据区,高128字节数据区间,特殊功能寄存器区。低128字节数据区分为三个区域:工作寄存器区,位寻找区和通用数据区。工作寄存器区4组工作寄存器;位寻找区既可以做位操作,也可以字节操作;通用数据区用于堆栈和存放程序运行时的数据和中间结果。
6.简述MCS-51单片机布尔处理器存储空间分配,片内RAM包含哪些可以位寻址的单元。位地址7DH与字节地址7DH如何区别?位地址7DH具体在片内RAM中的什么位置?
答:低128字节数据区的位寻找区和高128字节数据区的某些可位寻址的特殊功能寄存器。位地址7DH与字节地址7DH可通过不同的指令来区别,位地址7DH用位寻址指令来访问,字节地址7DH用字节寻址指令来访问,位地址7DH在低128字节数据区的位寻找区的2FH字节。
7.MCS-51单片机的程序状态寄存器PSW的作用是什么?常用标志有哪些位?作用是什么?
答:PSW是一个8位寄存器,用于设定CPU的状态和指示指令执行后的状态。
CY(PSW.7):进位标志。在执行加减运算指令时,如果运算结果的最高位(D7)发生了进位或借位,则CY由硬件自动置1。
AC(PSW.6):半进位标志位,也称为辅助标志位。在执行加减运算指令时,如果运算结果的低半字节(D3)发生了向高半字节进位或借位,则AC由硬件自动置1。
F0、F1(PSW.5 和PSW.1):用户标志位。用户可以根据需要对F0、F1赋予一定的含义,由用户置1和清0,作为软件标志。
RS1、RS0(PSW.4 和PSW.3):工作寄存器组选择控制位。通过对这两位设定,可以从4个工作寄存器组中选择一组作为当前工作寄存器。
OV(PSW.2):溢出标志位,有两种情况影响该位。一是执行加减运算时,如果D7或D6任一位,并且只一位发生了进位或借位,则OV自动置1,
P(PSW.0):奇偶标志位。每条指令执行完后,该位都会指示当前累加器A中1的个数。如果A中有奇数个1,则P自动置1。
8.MCS-51单片机复位后,CPU使用哪组工作寄存器?它们的地址是什么?用户如何改变当前工作寄存器组?
答: MCS-51单片机复位后,CPU使用0组工作寄存器。它们的地址是00H~07H。通过程序状态字PSW中的RS1、RS0标志位改变当前工作寄存器组。
9.什么叫堆栈?堆栈指针SP的作用是什么?
答: 堆栈是在RAM专门开辟的一个特殊用途的存储区。堆栈是按照“先进后出”(即先进入堆栈的数据后移出堆栈)的原则存取数据。堆栈指针SP是一个8位寄存器,其值为栈顶的地址,即指向栈顶,SP为访问堆栈的间址寄存器。
10.PC与DPTR各有哪些特点?有何异同?
答: PC与DPTR都是16位的寄存器。PC由两个8位的计数器PCH和PCL组成。PC实际是程序的字节地址计数器,它的内容是将要执行的下一条指令的地址,具有自加1功能。改变PC的内容就可以改变程序执行的方向。DPTR的高字节寄存器用DPH表示,低字节寄存器用DPL表示。DPTR既可以作为一个16位寄存器使用,也可以作为两个独立的8位寄存器使用。DPTR主要用于存放16位地址,以便对64KB的片外RAM和64KB的程序存储空间作间接访问。
11.测试哪个引脚,可以快捷地判断单片机是否正在工作?
答: 若要检查单片机是否工作,可以使用示波器查看ALE引脚是否有脉冲信号输出。
12.读端口锁存器和“读引脚”有何不同?各使用哪些指令?
答: 一种是读取锁存器原来的输出值,另一种情况是打开端口的缓冲器读取引脚上的信号,读端口锁存器,用MOV A,Pi指令。“读引脚”,要先用MOV Pi,#0FFH对相应端口写FFH,使输出场效应管T截止,才能够正确输入,再用MOV A,Pi指令。
13.MCS-51单片机的P0~P3口结构有何不同?用作通用I/O口输入数据时应注意什么?
答: P2口是一个双功能口,一是通用I/O口,二是以总线方式访问外部存储器时作为高8位地址口。其端口某一位的结构如图2-11所示,对比图2-10知,与P1口的结构类似,驱动部分基本上与P1口相同,但比P1口多了一个多路切换开关MUX和反相器3。P3口是一个多功能口,其某一位的结构见图2-12。与P1口的结构相比不难看出,P3口与P1口的差别在于多了“与非门”3和缓冲器4。正是这两个部分,使得P3口除了具有P1口的准双向I/O口的功能之外,还可以使用各引脚所具有的第2功能。P0多了一路总线输出(地址/数据)、总线输出控制电路(反相器3和与门4)、两路输出切换开关MUX及开关控制C,并且把上拉电阻换成了场效应管T1,以增加总线的驱动能力。用作通用I/O口输入数据时应注意要先用MOV Pi,#0FFH对相应端口写FFH,使输出场效应管T截止,才能够正确输入。
14.P0口用作通用I/O口输出数据时应注意什么?
答: P0口与其它端口不同,它的输出级无上拉电阻。当把它用作通用I/O口时,输出级是开漏电路,故用其输出去驱动NMOS输入时外接上拉电阻,这时每一位输出可以驱动4个LS型TTL负载。用作输入时,应先向端口锁存器写1。
15.什么叫时钟周期?什么叫机器周期?什么叫指令周期?时钟周期、机器周期与振荡周期之间有什么关系?
答: 时钟周期即振荡周期:为晶振的振荡周期,是最小的时序单位。状态周期:是振荡频率2分频后的时钟周期。显然,一个状态周期包含2个振荡周期。机器周期(MC):1个机器周期由6个状态周期、即12个振荡周期组成,是量度指令执行时间的单位。指令周期:是执行一条指令所需要的时间。一个指令周期由1~4个机器周期组成。
16.MCS-51单片机常用的复位电路有哪些?复位后机器的初始状态如何?
答: 复位电路有两种方式:上电自动复位电路和手动复位电路。复位后,程序计数器PC变为0000H,使单片机从程序存储器地址0000H单元开始执行。除P0~P3为FFH;SP为07H;SBUF为不确定。大部分特殊功能寄存器清零。
17.MCS-51单片机有几种低功耗工作方式?如何实现,又如何退出?
答: MCS-51单片机有空闲和掉电两种低功耗工作方式。当CPU执行完置IDL=1的指令后,系统就进入空闲方式。进入空闲方式之后,有两种方法可以退出。一种是任何中断请求被响应都可以由硬件将IDL位清0而结束空闲方式。另一种退出空闲方式的方法是硬件复位。当CPU执行完置PD=1的指令后,系统就进入掉电工作方式。对于一般的单片机来说,退出掉电方式的唯一方法是由硬件复位。
第3章 MCS-51指令系统及汇编程序设计
1.简述MCS-51汇编指令格式。
答: MCS-51汇编语言指令由四部分组成,其一般格式如下:
[标号:] 操作码 [操作数] [;注释]
格式中的方括号意为可以没有相应部分,可以没有标号、操作数和注释,至少要有操作码。其操作数部分最多可以是两项:
[第1操作数] [,第2操作数]
2.何谓寻址方式?MCS-51单片机有哪些寻址方式,是怎样操作的?各种寻址方式的寻址空间和范围是什么?
答: MCS-51单片机有7种寻址方式:立即数寻址、寄存器寻址、直接寻址、寄存器间接寻址、变址寻址、位寻址和指令寻址。可以分为两类:操作数寻址和指令寻址。
立即数寻址的寻址空间和范围是:在程序存储空间,随指令读入MOV A,#46H
直接寻址的寻址空间和范围是:片内RAM中,低128字节和SFR MOV A,46H
寄存器寻址的寻址空间和范围是:使用R0~R7、A、B、C、DPTR MOV A,R2
寄存器间接寻址的寻址空间和范围是:片内RAM:使用@Ri,SP;范围为256B,不含SFR,片外RAM:使用@Ri,@DPTR;范围为64KB MOV A,@R0 MOVX A,@DPTR
变址寻址的寻址空间和范围是:使用@A+PC,@A+DPTR;在程序存储器中;
范围分别为PC之后256B之内和64KB全空间 MOVC A,@A+DPTR
位寻址的寻址空间和范围是:使用位地址;在位寻址空间;RAM的20H~2FH和SFR SETB 36H
指令绝对寻址的寻址空间和范围是:操作数是目标地址;在程序存储空间;
范围为2KB或64KB全空间 AJMP FIRST LJMP SECON
指令相对寻址的寻址空间和范围是:操作数是相对地址;在程序存储空间;范围﹣128~127 SJMP LOOP
3.访问片内RAM低128字节使用哪些寻址方式?访问片内RAM高128字节使用什么寻址方式?访问SFR使用什么寻址方式?
答: 访问片内RAM低128字节使用直接寻址,寄存器间接寻址,位寻址;访问片内RAM高128字节使用寄存器间接寻址;访问SFR使用直接寻址,位寻址。
4.访问片外RAM使用什么寻址方式?
答: 访问片外RAM使用寄存器间接寻址
5.访问程序存储器使用什么寻址方式?指令跳转使用什么寻址方式?
答: 访问程序存储器使用指令绝对寻址,指令相对寻址。指令跳转使用指令绝对寻址,指令相对寻址。
6.分析下面指令是否正确,并说明理由。
MOV R3,R7 错,两个操作数不能同时为工作寄存器
MOV B,@R2 对
DEC DPTR 错,不存在
MOV 20H.8,F0 错,位传送指令必须用C
PUSH DPTR
CPL 36H 错,不存在
MOV PC,#0800H 错,PC不能访问
7.分析下面各组指令,区分它们的不同之处。
MOV A,30H 与 MOV A,#30H
前者表示:(30H)→A 后者表示:30H→A
MOV A,R0 与 MOV A,@R0
前者表示:(R0)→A 后者表示:((R0))→A
MOV A,@R1 与 MOVX A,@R1
前者表示:在片内数据存储器((R1))→A
后者表示:在片外数据存储器((R1))→A
MOVX A,@R0 与 MOVX A,@DPTR
前者R0表示8位地址 后者DPTR表示16位地址
MOVX A,@DPTR 与 MOVC A,@A+DPTR
前者表示:((DPTR))→A 后者表示:((DPTR)+(A))→A
8.在MCS-51单片机的片内RAM中,已知(30H)=38H,(38H)=40H,(40H)=48H,(48H)=90H。请说明下面各是什么指令和寻址方式,以及每条指令执行后目的操作数的结果。
MOV A,40H ;数据传送,直接寻址,(A)=48H
MOV R0,A ;数据传送,寄存器寻址,(R0)=48H
MOV P1,#0FH ;数据传送,立即数寻址,(P1)=0FH
MOV @R0,30H ;数据传送,直接寻址,(48H)=38H
MOV DPTR,#1234H ;数据传送,立即数寻址,(DPTR)=1234H
MOV 40H,30H ;数据传送,直接寻址,(40H)=38H
MOV R0,38H ;数据传送,直接寻址,(R0)=40H
MOV P0,R0 ;数据传送,直接寻址,(P0)=40H
MOV 28H,#30H ;数据传送,立即数寻址,(28H)=30H
MOV A,@R0 ;数据传送,寄存器间接寻址,(A)=38H
9.已知(A)=23H,(R1)=65H,(DPTR)=1FECH,片内RAM(65H)=70H, ROM(205CH)=64H。试分析下列各条指令执行后目标操作数的内容。
MOV A,@R1 ;(A)=70H
MOVX @DPTR,A ;(1FECH)=70H
MOVC A,@A+DPTR ;(A)=64H
XCHD A,@R1 ;(A)=65H
10.已知(A)=76H,(R1)=76H,(B)=4,CY=1,片内RAM(76H)=0D0H,(80H)=6CH。试分析下列各条指令执行后目标操作数的内容和相应标志位的值。
ADD A,@R1 ;(A)=46H,CY=1
SUBB A,#75H ;(A)=0D0H,CY=1
MUL AB ;(A)=40H,(B)=03H
DIV AB ;(A)=15H,(B)=01H
ANL 76H,#76H ;(76H)=50H
ORL A,#0FH ;(A)=1FH
XRL 80H,A ;(80H)=73H
11.已知(A)=83H,(R0)=17H,(17H)=34H,试分析当执行完下面程序段后累加器A、R0、17H单元的内容。
ANL A,#17H ;(A)=03H
ORL 17H,A ;(17H)=37H
XRL A,@R0 ;(A)=34H
CPL A ;(A)=0CBH
12.阅读下面程序段,说明该段程序的功能。
MOV R0,#40H
MOV R7,#10
CLR A
LOOP:
MOV @R0,A
INC A
INC R0
DJNZ R7,LOOP
SJMP $
答:把0,1,2,3……数列送到40H开始的10个单元中。
13.阅读下面程序段,说明该段程序的功能。
MOV R0,#40H
MOV A,R0
INC R0
ADD A,@R0
MOV 43H,A
CLR A
ADDC A,#0
MOV 42H,A
SJMP $
答:40H加41H单元的数,结果送42H:43H
14.阅读下面程序段,说明该段程序的功能。
MOV A,30H
MOV B,#5
MUL AB
ADD A,31H
MOV 33H,A
CLR A
ADDC A,B
MOV 32H,A
SJMP $
答:(30H)5+(31H)→(32H:33H)
15.编写程序,用位处理指令实现“P1.4=P1.0∨(P1.1∧P1.2)∨P1.3”的逻辑功能。
MOV C,P1.1
ANL C,P1.2
ORL C,P1.0
ORL C,P1.3
MOV P1.3,C
16.编写程序,若累加器A的内容分别满足下列条件,则程序转到LABLE存储单元。设A中存放的的无符号数。
(1)A≥10; (2)A>10; (3)A≤10。
(1)
CJNE A,#10,NEXT
LJMP LABLE
NEXT:
JNC LABLE
(2)
CJNE A,#10,NEXT
LJMP NEXT2
NEXT:
JNC LABLE
NEXT2:
(3)
CJNE A,#10,NEXT
LJMP LABLE
NEXT:
JC LABLE
17.编写程序,查找片内RAM的30H~50H单元中是否有55H这一数据,若有,则51H单元置为FFH;若未找到,则将51H单元清0。
MOV R0,29H
NEXT:
INC R0
CJNE R0,#51H,NEXT2
MOV 51H,#0FFH
AJMP OVER
NEXT2:
CJNE @R0,#55H,NEXT
MOV 51H,#0
OVER:
18.编写程序,查找片内RAM的30H~50H单元中出现0的次数,并将查找的结果存入51H单元。
MOV R0,30H
MOV 51H,#0
NEXT:
CJNE @R0,#00H,NEXT2
INC 51H
NEXT2:
INC R0
CJNE R0,#51H,NEXT
19.在片外RAM中有一个数据块,存有若干字符、数字,首地址为SOURCE要求将该数据块传送到片内RAM以DIST开始的区域,直到遇到字符“$”时结束($也要传送,它的ASCII码为24H)。
MOV DPTR,#SOURCE
MOV R0,#DIST
NEXT:
MOVX A,@DPTR
MOV @R0,A
INC DPTR
INC R0
CINE A,#24H,NEXT
20.片内RAM的30H和31H单元中存放着一个16位的二进制数,高位在前,低位在后。编写程序对其求补,并存回原处。
CLR C
MOV A,#0
SUBB A,31H
MOV 31H,A
MOV A,#0
SUBB A,30H
MOV 30H,A
21.片内RAM中有两个4字节压缩的BCD码形式存放的十进制数,一个存放在30H~33H单元中,另一个存放在40H~43H单元中。编写程序将它们相加,结果的BCD码存放在30H~33H中。
CLR C
MOV R0,#30H
MOV R1,#40H
MOV R2,#4
NEXT:
MOV A,@R0
ADDC A,@R1
MOV @R0,A
INC R0
INC R1
DJNZ R2,NEXT
22.编写程序,把片外RAM从2000H开始存放的16字节数据,传送到片内从30H开始的单元中。
MOV DPTR,#2000H
MOV R0,#30H
MOV R1,#0
NEXT:
MOVX A,@DPTR
MOV @R0,A
INC DPTR
INC R0
INC R1
CINE R1,#16H,NEXT
第4章 单片机C语言及程序设计
1.用C51编程较汇编语言有哪些优势?
答:(1)编程容易
(2)容易实现复杂的数值计算
(3)容易阅读、调试、维护程序
(4)容易实现模块化开发
(5)程序可移植性好
2.C51字节数据、整型数据以及长整型数据在存储器中的存储方式各是怎样的?
答:字符变量(char)无论是unsigned char数据还是signed char数据,均为1个字节,即8位,因此被直接存储在RAM中,可能存储在0~0x7f区域(包括位寻址区域),也可能存储在0x80~0xff区域,与变量的定义有关。
整型变量(int)不管是unsigned int数据还是signed int数据,均为2个字节,即16位,其存储方法是高位字节保存在低地址(在前面),低位字节保存在高地址(在后面)。
长整型变量(long)为4个字节,即32位,其存储方法与整型数据一样,是最高位字节保存的地址最低(在最前面),最低位字节保存的地址最高(在最后面)。
3.C51定义变量的一般格式是什么?变量的4种属性是什么?特别要注意存储区属性。
答:[存储类型] 数据类型 [存储区] 变量名1[=初值] [,变量名2[=初值]] [,…]
变量的4种属性是存储类型,数据类型,存储区,变量名
4.C51的数据存储区域类型有哪些?各种存储区域类型是哪种存储空间,存储范围是什么?如何将变量定义存储到确定的位置?
答:bit 片内数据区的位寻找区,位地址0x00~0x7f,128位(字节地址0x20~0x2f)
data 直接寻址片内数据区的低128字节
bdata 片内数据区的位寻址区0x20~0x2f,也可字节访问,16字节
idata 间接寻址片内数据区的256字节,与MOV @Ri 对应
pdata 分页寻址片外数据区的256字节,与MOVX @Ri 对应,P2不变
xdata 片外数据区的全空间,64KB
code 全部程序存储空间,64KB
绝对定位关键字_at_ ,指针,库函数的绝对定位宏。
5.C51位变量的定义格式是什么?如何定义bdata型字节变量的位变量?
答:[存储类型] bit 位变量名1[=初值] [,位变量名2[=初值]] [,…]
sbit 位变量名 = bdata型变量名^位号常数
6.如何定义8位字节型特殊功能寄存器?如何定义16位特殊功能寄存器?如何定义特殊功能寄存器的位变量?
答:sfr 特殊功能寄存器名 = 地址常数
sfr16 特殊功能寄存器名 = 地址常数
sbit 位变量名 = 特殊功能寄存器名^位号常数
7.C51专用指针定义的一般格式是什么?如何确定专用指针定义的指向空间和指针变量本身存储的空间?
答:[存储类型] 数据类型 指向存储区 *[指针存储区] 指针名1 [,*[指针存储区] 指针名2,…]
*的左面是指向存储区,*的右面是指针存储区
8.C51函数定义的一般形式是什么?如何定义中断处理程序?如何选择工作寄存器组?
答:返回类型 函数名(形参表) [函数模式] [reentrant] [interrupt m] [using n]
{
局部变量定义
执行语句
}
[interrupt m]字段中的m定义中断处理程序的中断号
[using n]字段中的n选择工作寄存器组
9.在C51中,对汇编语言函数的命名规则是怎样的,具体地说:不传递参数的函数名格式是什么?通过寄存器传递参数的函数名格式是什么?传递参数重入函数的函数名格式是什么?
答:?PR?函数名?模块名 //不传递参数
?PR?_函数名?模块名 //通过寄存器传递参数
?PR?_?函数名?模块名 //对重入函数通过堆栈传递参数
10.在C51中,函数返回值传递的规则是什么?
答:(1)调用时参数的传递
分三种情况:少于等于3个参数时通过寄存器传递(寄存器不够用时通过存储区传递),多于3个时有一部分通过存储区传递,对于重入函数参数通过堆栈传递。通过寄存器传递速度最快。
(2)函数返回值的传递
当函数有返回值时,其传递都是通过寄存器
11.在C51中,怎样嵌入汇编语言程序?怎样进行处理实现混合编程?
答:其方法是用编译控制指令“#pragma src”、“#pragma asm”和“#pragma endasm”实现。编译控制命令“#pragma src”是控制编译器将C源文件编译成汇编文件,“#pragma src”要放在文件的开始;“#pragma asm”和“#pragma endasm”指示汇编语言程序的开始和结束,分别放在汇编程序段的前面和后面。
对于函数的调用方法,与调用汇编语言中的函数一样,
在C语言文件中调用汇编语言中的函数,必须先声明再调用。声明格式如下:
extern 返回值类型 函数名(参数表);
12.在C51中如何定义模块名?在C51文件中的模块名是什么?
答:模块定义格式如下:
NAME 模块名
13.在汇编语言文件中:怎样声明函数段?怎样声明公共函数?怎样声明引用函数?怎样声明引用变量?定义函数的格式是什么?
答:对本模块定义的函数段作声明,其格式为:
?PR?函数名?模块名 SEGMENT CODE
公共函数声明。声明格式为:
PUBLIC 函数名
引用声明。声明格式为:
EXTRN CODE(函数名)
引用声明。声明格式为:
EXTRN 存储区域类型(变量名)
汇编语言函数的格式如下:
RSEG ?PR?函数名?模块名
函数名:
14.在C51中怎样把函数定义到确定的位置?
答:对函数的定位方法,
CSEG AT 001BH
15.如何在C51文件和汇编语言文件中相互调用对方文件中的函数?
答:汇编语言文件中对于函数的调用方法,与调用汇编语言中的函数一样,如:
LCALL DISPLAY
在C语言文件中调用汇编语言中的函数,必须先声明再调用。声明格式如下:
extern 返回值类型 函数名(参数表);
例如: extern unsigned char right_shift ( char, char );
16.在C51中,如何访问DATA空间、PDATA空间、XDATA空间、CODE空间某个确定地址单元?
答:用指针定义的访问存储器的宏
使用时需要用预处理命令把该头文件包含到文件中,形式为:#include
。
(1)按字节访问存储器宏的形式
宏名[地址]
(2)按整型数访问存储器宏的形式
宏名[下标]
17.在某程序中需要定义如下变量:
(1)定义数码管的显示0~9的共阴极显示代码(0x3f,0x06,0x5b,0x4f,0x66, 0x6d,0x7d,0x07, 0x7f, 0x6f)数组dis_code,将其定义在CODE区。
(2)定义定时器/计数器0的赋计数值的高、低字节变量TL0_L和TH0_H,将其定义在DATA去区的0x30、0x31处。
(3)定义长度为20的无符号字符型数组data_buf于IDATA区中。
(4)定义长度为100的无符号字符型数组data_array于XDATA区中。
(5)先定义一个无符号字符型变量status于BDATA区中,再定义8个与status的8个位对应的位变量flag_lamp1、flag_lamp2、flag_machine1、flag_machine2、flag_port1、flag_port2、flag_calcu1和calcu2(从低位到高位)。
答:(1)unsigned char code dis_code[10]={0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07,0x7f,0x6f};
(2)unsigned char data TL0_L _at_ 0x30, TH0_H _at_ 0x31;
(3)unsigned char idata data_buf[20];
(4)unsigned char xdata data_array[100];
(5)unsigned char bdata status;
sbit flag_lamp1=status^0;
sbit flag_lamp2=status^1;
sbit flag_machine1=status^2;
sbit flag_machine2=status^3;
sbit flag_port1=status^4;
sbit flag_port2=status^5;
sbit flag_calcu1=status^6;
sbit flag_calcu2=status^7;
18.在89C52单片机中增加了定时器/计数器2(T2),修改头文件“REG51.H”,添加如下内容:
(1)特殊功能寄存器T2CON、T2MOD、RCAP2L、RCAP2H、TL2、TH2,地址分别为0xc8~ 0xcd。
(2)对T2CON的8个位分别定义位变量CP_RL2、C_T2、TR2、EXEN2、TCLK、RCLK、EXF2、和TF2(从低位到高位)。
(3)定义位变量T2、T2EX对应于P1口的第0位和第1位;定义位变量ET2对应于EI的第5位;定义位变量PT2对应于IP的第5位;
(4)对P1口的8个位分别定义位变量P0_0、P0_1、P0_2、P0_3、P0_4、P0_5、P0_6和P0_7(从低位到高位)。
答:(1)
sfr T2CON=0xc8;
sfr T2MOD=0xc9;
sfr RCAP2L=0xca;
sfr RCAP2H=0xcb;
sfr TL2=0xcc;
sfr TH2=0xcd;
(2)
sbit CP_RL2=T2CON^0;
sbit C_T2=T2CON^1;
sbit TR2=T2CON^2;
sbit EXEN2=T2CON^3;
sbit TCLK=T2CON^4;
sbit RCLK=T2CON^5;
sbit EXF2=T2CON^6;
sbit TF2=T2CON^7;
(3)
sbit T2=P1^0;
sbit T2EX=P1^1;
sbit ET2=EI^5;
sbit PT2=IP^5;
(4)
sbit P0_0=P0^0;
sbit P0_1=P0^1;
sbit P0_2=P0^2;
sbit P0_3=P0^3;
sbit P0_4=P0^4;
sbit P0_5=P0^5;
sbit P0_6=P0^6;
sbit P0_7=P0^7;
19.编写一C51函数,把从键盘输入的5位十进制数数转换成一个无符号整型数(假设未超出整型数范围)。设从键盘输入的数存放在一无符号数组中,低位数为低下标元素。
unsigned char data key_buffer[5];
unsigned int trans_int(void)
{
unsigned char data i;
unsigned int data temp=0;
for(i=0;i<5;i++)
{
temp=temp*10+key_buffer[i]-0x30;
}
return temp;
}
20.编写一C51函数,把一整型数按十进制数将其各位分离,分离后放在一无符号数组中,便于显示。要求把低位数作为低下标元素。
unsigned char data shu[5];
void main(unsigned int x)
{
unsigned int temp;
unsigned char i;
for(i=0;i<4;i++)
{
shu[i]=temp%10;
temp=temp/10;
}
shu[4]=temp;
}
21.编写一C51函数,使用专用指针,把片外数据存储器中从0x100开始的30个字节数据,传送到片内从0x40开始的区域中。
void main()
{
unsigned char data i,*dpt;
unsigned char xdata *xdpt;
dpt=0x40;
xdpt=0x100;
for(i=0;i<30;i++)
*(dpt+i)=*(xdpt+i);
}
22.编写一C51程序,实现从P1口输出产生的流水灯,要求用汇编语言函数实现数据左移或右移。
#pragma src
#include
void main()
{
unsigned char temp,i;
while(1)
{
temp=0x55;
P1=temp;
delay();
#pragma asm
MOV A,temp
RR A
MOV temp,A
#pragma endasm
P1=temp;
delay();
}
}
23.某单片机系统的P2口接一数模转换器DAC0832输出模