单片机原理及接口技术课后习题答案.doc
单片机原理及接口技术课后习题答案学院:信息学院学号:14082200152班级:08电信4班姓名:张桂星序号:10号2011年1月4日星期二(晚)第1章 单片机概述1除了单片机这一名称之外,单片机还可称为 和 。答:微控制器,嵌入式控制器。2单片机与普通微型计算机的不同之处在于其将 、 、和 3部分集成于一块芯片上。答:CPU、存储器、I/O口。38051与8751的区别是 。A内部数据存储单元数目不同 B内部数据存储器的类型不同C内部程序存储器的类型不同 D内部寄存器的数目不同答:C。4在家用电器中使用单片机应属于微计算机的 。A辅助设计应用;B测量、控制应用;C数值计算应用;D数据处理应用答:B。5微处理器、微计算机、微处理机、CPU、单片机它们之间有何区别?答:微处理器、微处理机和CPU都是中央处理器的不同称谓;而微计算机、单片机都是一个完整的计算机系统,单片机特指集成在一个芯片上的用于测控目的的单片微计算机。6MCS-51系列单片机的基本型芯片分别为哪几种?它们的差别是什么?答:MCS-51系列单片机的基本型芯片分别是8031、8051和8751。它们的差别是在片内程序存储器上。8031无片内程序存储器,8051片内有4KB的程序存储器ROM,而8751片内集成有4KB的程序存储器EPROM。7为什么不应当把51系列单片机称为MCS-51系列单片机?答:因为MCS-51系列单片机中的“MCS”是Intel公司生产的单片机的系列符号,而51系列单片机是指世界各个厂家生产的所有与8051的内核结构、指令系统兼容的单片机。8AT89C51单片机相当于MCS-51系列单片机中的哪一种型号的产品?答:相当于MCS-51系列中的87C51,只不过是AT89C51芯片内的4KB Flash存储器取代了87C51片内的4KB的EPROM。第2章 AT89C51单片机片内硬件结构1在AT89C51单片机中,如果采用6MHz晶振,一个机器周期为 。答:2µs2AT89C51单片机的机器周期等于 个时钟振荡周期。答:12。3内部RAM中,位地址为40H、88H的位,该位所在字节的字节地址分别为 和 。答:28H;88H。4片内字节地址为2AH单元的最低位的位地址是 ;片内字节地址为88H单元的最低位的位地址是 。答:50H;88H。5若A中的内容为63H,那么,P标志位的值为 。答:P标志位的值为0。6AT89C51单片机复位后,R4所对应的存储单元的地址为 ,因上电时PSW = 。这时当前的工作寄存器区是 组工作寄存器区。答:04H;00H;0。7内部RAM中,可作为工作寄存器区的单元地址为 H H。答:00H;1FH。8通过堆栈操作实现子程序调用,首先要把 的内容入栈,以进行断点保护。调用返回时,再进行出栈保护,把保护的断点送回到 。答:PC;PC。9AT89C51单片机程序存储器的寻址范围是由程序计数器PC的位数所决定的,因为AT89C51单片机的PC是16位的,因此其寻址的范围为 KB。答:64KB。10判断下列 项说法是正确的。AAT89C51单片机的CPU是由RAM和EPROM组成的B区分片外程序存储器和片外数据存储器的最可靠的方法是看其位于地址范围的低端还是高端C在AT89C51单片机中,为使准双向的I/O口工作在输入方式,必须保证它被事先预置为1DPC可以看成是程序存储器的地址指针答: A. 错; B. 错;C. 对;D. 对。11判断以下有关PC和DPTR的结论 是正确的。ADPTR是可以访问的,而PC不能访问B它们都是16位寄存器C在单片机运行时,它们都具有自动加“1”的功能DDPTR可以分为2个8位的寄存器使用,但PC不能答:A. 对; B. 对;C. 错;D. 对。12判断下列说法 项是正确的。A程序计数器PC不能为用户编程时直接访问,因为它没有地址B内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用CAT89C51单片机共有21个特殊功能寄存器,它们的位都是可用软件设置的,因此,是可以进行位寻址的。答:A. 对; B. 错;C. 错。13PC的值是 。A当前正在执行指令的前一条指令的地址B当前正在执行指令的地址C当前正在执行指令的下一条指令的地址D控制器中指令寄存器的地址答:A. 错;B. 错;C. 对;D. 错。14判断下列说法 项是正确的。APC是一个不可寻址的特殊功能寄存器B单片机的主频越高,其运算速度越快C在AT89C51单片机中,一个机器周期等于1msD特殊功能寄存器内存放的是栈顶首地址单元的内容答:A. 对;B. 对;C. 错;D.错。15AT89C51单片机的片内都集成了哪些功能部件?各个功能部件的最主要的功能是什么?(1)1个微处理器(CPU);(2)128个数据存储器(RAM)单元;(3)4KB Flash程序存储器;(4)4个8位可编程并行I/O口(P0口、P1口、P2口、P3口);(5)1个全双工串行口;(6)2个16位定时器/计数器;(7)一个中断系统,5个中断源,2个优先级;(8)21个特殊功能寄存器(SFR)。16说明AT89C51单片机的引脚的作用,该引脚接高电平和低电平时各有何种功能?答:当脚为高电平时,单片机读片内程序存储器(4KB Flash),但在PC值超过0FFFH(即超出4KB地址范围)时,将自动转向读外部程序存储器内的程序。当脚为低电平时,对程序存储器的读操作只限定在外部程序存储器,地址为0000HFFFFH,片内的4KB Flash程序存储器不起作用。1764KB程序存储器空间有5个单元地址对应AT89C51单片机5个中断源的中断入口地址,请写出这些单元的入口地址及对应的中断源。答:64KB程序存储器空间中有5个特殊单元分别对应于5个中断源的中断服务程序的入口地址,见下表。表 5个中断源的中断入口地址入口地址中断源0003H外部中断0 ()000BH定时器0 (T0)0013H外部中断1 ()001BH定时器1 (T1)0023H串行口18当AT89C51单片机运行出错或程序陷入死循环时,如何摆脱困境?答:按下复位按钮。第3章 AT89C51单片机的指令系统1在基址加变址寻址方式中,以 作为变址寄存器,以 或 作为基址寄存器。答:A,PC,DPTR。2指令格式是由 和 组成,也可仅由 组成。答:操作码,操作数,操作码。3假定累加器A中的内容为30H,执行指令1000H:MOVC A,A+PC后,把程序存储器 单元的内容送入累加器A中。答:1031H。4在AT89C51单片机中,PC和DPTR都用于提供地址,但PC是为访问 存储器提供地址,而DPTR是为访问 存储器提供地址。答:程序,数据。5在寄存器间接寻址方式中,其“间接”体现在指令中寄存器的内容不是操作数,而是操作数的 。答:地址。6已知程序执行前有(A) = 02H,(SP) = 52H,(51H) = FFH,(52H) = FFH。下述程序执行后,(A) = ,(SP) = ,(51H) = ,(52H) = ,(PC) = 。POP DPHPOP DPLMOV DPTR,#4000HRL AMOV B,AMOVC A,A+DPTRPUSH AccMOV A,BINC AMOVC A,A+DPTRPUSH AccRETORG 4000HDB 10H,80H,30H,50H,30H,50H答:(A)=50H,(SP)=50H,(51H)=30H,(52H)=50H,(PC)=5030H。7假定(A) = 83H,(R0) = 17H,(17H) = 34H,执行以下指令后,(A) = 。ANL A,#17HORL 17H,AXRL A,R0CPL A答:(A)=0CBH。8假设(A) = 55H,(R3) = 0AAH,在执行指令“ANL A,R5”后,(A) = ,(R3) = 。答:(A)=00H,(R3)=0AAH。9如果(DPTR) = 507BH,(SP) = 32H,(30H) = 50H,(31H) = 5FH,(32H) = 3CH,则执行下列指令后,(DPH) = ,(DPL) = ,(SP) = 。POP DPHPOP DPLPOP SP答:(DPH)=3CH,(DPL)=5FH,(SP)=50H。10假定,(SP) = 60H,(A) = 30H,(B) = 70H,执行下列指令后,SP的内容为 ,61H单元的内容为 ,62H单元的内容为 。PUSH AccPUSH B答:(SP)=62H,(61H)=30H,(62H)=70H。11判断下列说法 项是正确的。A立即寻址方式是被操作的数据本身就在指令中,而不是它的地址在指令中B指令周期是执行一条指令的时间C指令中直接给出的操作数称为直接寻址答:A对;B对; C错。12判断以下指令的正误。(1)MOV 28H,R2 (2)DEC DPTR (3)INC DPTR (4)CLR R0(5)CPL R5 (6)MOV R0,R1 (7)PHSH DPTR (8)MOV F0,C(9)MOV F0,Acc.3 (10)MOVX A,R1 (11)MOV C,30H (12)RLC R0答:(1)错(2)错(3)对(4)错(5)错(6)错(7)错(8)对(9)错(10)对 (11)对(12)错。13访问SFR,可使用哪些寻址方式?答:只能使用直接寻址方式。14下列程序段的功能是什么?PUSHAccPUSH BPOP AccPOP B答:A的内容与B的内容互换。15写出完成如下要求的指令,但是不能改变未涉及位的内容。(1)把ACC.3,ACC.4,ACC.5和ACC.6清“0”。(2)把累加器A的中间4位清“0”。(3)使ACC.2和ACC.3置“1”。答:(1)ANL A,#87H (2)ANL A,#0C3H (3)ORL A,#0CH16借助本书中的表3-2(指令表),对如下指令代码(十六进制)进行手工反汇编。FF C0 E0 E5 F0 F0答:MOV R7,APUSH AMOV A ,BMOVX DPTR,A第4章 AT89C51单片机汇编语言程序设计1已知程序执行前有A = 02H,SP = 42H,(41H) = FFH,(42H) = FFH。下述程序执行后,A = ;SP = ;(41H) = ;(42H) = ;PC = 。POP DPHPOP DPLMOV DPTR,#3000HRL AMOV B,AMOVC A,A+DPTRPUSH AccMOV A,BINC AMOVC A,A+DPTRPUSH AccRETORG 3000HDB 10H,80H,30H,80H,50H,80H答: A=80H,SP=40H,(51H)=50H,(52H)=80H ,PC=8050H。2说明伪指令的作用。“伪”的含义是什么?常用伪指令的功能如何?答:伪指令不属于指令系统中的汇编语言指令,它是程序员发给汇编程序的控制命令。只有在汇编前的源程序中才有伪指令。所以“伪”体现在汇编后,伪指令没有相应的机器代码产生。3解释手工汇编、机器汇编、交叉汇编、反汇编术语概念。答:(1)手工汇编:手工编程,首先把程序用助记符指令写出,然后通过查指令的机器代码表,逐个把助记符指令“翻译”成机器代码,这种人工查表“翻译”指令的方法称为手工汇编。(2)机器汇编:是借助于微型计算机上的软件(汇编程序)来代替手工汇编,完成把助记符指令“翻译”成机器代码的工作。(3)交叉汇编:使用微型计算机来完成汇编,而汇编后得到的机器代码却是在另一台计算机(这里是单片机)上运行,称这种机器汇编为交叉汇编。(4)反汇编:将二进制的机器代码语言程序翻译成汇编语言源程序的过程。4下列程序段经汇编后,从1000H开始的各有关存储单元的内容是什么?ORG 1000HTAB1 EQU 1234HTAB2 EQU 3000HDB "MAIN"DW TAB1,TAB2,70H答:4D 41 49 4E 12 34 30 00 00 70 5设计子程序时应注意哪些问题?答:在编写子程序时应注意以下问题。(1)子程序的第一条指令前必须有标号。(2)使用子程序调用指令时,有两条调用指令可供使用。使用绝对调用指令(ACALL addr11)要注意,被调用的子程序的首地址与本绝对调用指令的下一条指令的高5位地址相同,即只能在同一2KB程序存储区内。使用长调用指令(LCALL addr16)时,addr16为直接调用的子程序的目标地址,也就是说,被调用的子程序可放置在64KB程序存储器区的任意位置。(3)子程序结构中必须用到堆栈,堆栈通常用来保护断点和现场保护。(4)子程序返回主程序时,最后一条指令必须是RET指令。(5)子程序可以嵌套,即主程序可以调用子程序,子程序又可以调用另外的子程序。6试编写一个程序,将内部RAM中45H单元的高4位清“0”,低4位置“1”。答:参考程序如下:MOVA,45HANLA,#0FHORLA,#0FHMOV45H,A7试编写程序,查找在内部RAM的30H50H单元中是否有0AAH这一数据。若有,则将51H单元置为“01H”;若未找到,则将51H单元置为“00H”。答:参考程序如下:START:MOVR0,#30HMOVR2,#20HLOOP:MOVA,R0CJNEA,#0AAH,NEXTMOV51H,#01HLJMPEXITNEXT:INCR0DJNZR2,LOOPMOV51H,#00HEXIT:RET8试编写程序,查找在内部RAM的20H40H单元中出现“00H”这一数据的次数,并将查找到的结果存入41H单元。答:参考程序如下:START:MOV41H,#0MOVR0,#20HMOVR2,#20HLOOP:MOVA,R0JNZNEXTINC41HNEXT:INCR0DJNZR2,LOOPRET9在内部RAM的21H单元开始存有一组单字节无符号数,数据长度为20H,编写程序,要求找出最大数存入MAX单元。答:MOV R0, #21H ;起始地址. MOV MAX,#00H ;先用0当做最大值. MOV R2, #20H ;数据长度.LOOP: MOV A, R0 ;取来一个数据. CLR C SUBB A, MAX ;减“最大值”. JNC rel1 ;不够减就算了. MOV A, R0 ;够减,就把这个数据. MOV MAX,A ;当做最大值.rel1: INC R0 ;转向下一个. DJNZ R2, LOOP ;循环. SJMP $ ;结束.10若SP = 60H,标号LABEL所在的地址为3456H。LCALL指令的地址为2000H,执行如下指令2000H LCALL LABEL后,堆栈指针SP和堆栈内容发生了哪些变化?PC的值等于什么?如果将指令LCALL直接换成ACALL是否可以?如果换成ACALL指令,可调用的地址范围是什么?答: (1)SP=SP+1=61H (61H)=PC的低字节=03H SP=SP+1=62H (62H)=PC的高字节=20H(2)PC=3456H(3)可以(4)2KB=2048 Byte第5章 AT89C51单片机的中断系统1外部中断1的中断入口地址为 。定时器1的中断入口地址为 。答:0013H;001BH。2若(IP) = 00010100B,则优先级最高者为 ,最低者为 。答:外部中断1;定时器T1。3AT89C51单片机响应中断后,产生长调用指令LCALL,执行该指令的过程包括:首先把 的内容压入堆栈,以进行断点保护,然后把长调用指令的16位地址送 ,使程序执行转向 中的中断地址区。答:PC、PC、程序存储器。4判断AT89C51单片机对外中断请求源响应的最快响应时间为3个机器周期 。答:对。5下列说法正确的是 。A各中断源发出的中断请求信号,都会标记在AT89C51单片机的IE寄存器中B各中断源发出的中断请求信号,都会标记在AT89C51单片机的TMOD寄存器中C各中断源发出的中断请求信号,都会标记在AT89C51单片机的IP寄存器中D各中断源发出的中断请求信号,都会标记在AT89C51单片机的TCON与SCON寄存器中答:D。6中断查询确认后,在下列各种AT89C51单片机运行情况下,能立即进行响应的是 。A当前正在进行高优先级中断处理B当前正在执行RETI指令C当前指令是DIV指令,且正处于取指令的机器周期D当前指令是MOV A,R3答:D。7在AT89C51单片机的中断请求源中,需要外加电路实现中断撤销的是 。A电平方式的外部中断B脉冲方式的外部中断C外部串行中断D定时中断答:A。8下列说法正确的是 。A同一级别的中断请求按时间的先后顺序响应B同一时间同一级别的多中断请求将形成阻塞,系统无法响应C低优先级中断请求不能中断高优先级中断请求,但是高优先级中断请求能中断低优先级中断请求D同级中断不能嵌套答:A、C、D。9中断服务子程序与普通子程序有哪些相同和不同之处?答:RETI指令在返回时,同时清除中断系统中相应的优先级触发器,以允许下次中断,而RET指令则没有这个操作。除了这一点两条指令不同外,其他操作都相同。10AT89C51单片机响应外部中断的典型时间是多少?在哪些情况下,CPU将推迟对外部中断请求的响应?答:略。11编写外部中断1为跳沿触发的中断初始化程序段。答:SETBIT1SETBEX1SETBEA12中断响应的条件是什么?答:略。13某系统有3个外部中断源1、2、3,当某一中断源发出的中断请求使引脚变为低电平时(见图5-10),便要求CPU进行处理,它们的优先处理次序由高到低为3、2、1,中断处理程序的入口地址分别为1000H、1100H、1200H。试编写主程序及中断服务子程序(转至相应的中断处理程序的入口即可)。答:参见电路如图5-10所示,参考程序如下:ORG0000HLJMPMAINORG0013HLJMPINT_EX1ORG0030HMAIN:CLRIT0;采用电平触发,低电平有效中断SETBEX1;允许外部中断1SETBEAWAIT: LJMPWAIT;用原地跳转代替一段用户程序;以下为外部中断1服务子程序INT_EX1:JNBP1.2,NEXT1;P1.2=0,不是3号中断,跳转NEXT1 LJMPINT_IR3 ;是3号中断,跳转到对应的中断处理程序NEXT1: JNBP1.1,NEXT2;P1.1=0,不是2号中断,跳转NEXT2 LJMPINT_IR2;跳转到2号中断处理程序NEXT2: LJMPINT_IR1;跳转到1号中断处理程序ORG1000HINT_IR3:插入相应中断处理程序RETI;中断返回ORG1100HINT_IR2:插入相应中断处理程序RETI;中断返回ORG1200HINT_IR1:插入相应中断处理程序RETI;中断返回第6章 AT89C51单片机的定时器/计数器1下列 项说法是正确的。A特殊功能寄存器SCON,与定时器/计数器的控制无关B特殊功能寄存器TCON,与定时器/计数器的控制无关C特殊功能寄存器IE,与定时器/计数器的控制无关D特殊功能寄存器TMOD,与定时器/计数器的控制无关答:A对;B;错C错;D错。2如果采用的晶振的频率为3MHz,定时器/计数器工作在方式0、1、2下,其最大定时时间各为多少?答:因为机器周期 所以定时器/计数器工作方式0下,其最大定时时间为 同样可以求得,方式1下的最大定时时间为262.144ms;方式2下的最大定时时间为1024ms。3定时器/计数器用作定时器模式时,其计数脉冲由谁提供?定时时间与哪些因素有关?答:定时器/计数器用作定时器时,其计数脉冲由系统振荡器产生的内部时钟信号12分频后提供。定时时间与时钟频率和定时初值有关。4定时器/计数器用作计数器模式时,对外界计数频率有何限制?答:由于确认1次负跳变要花2个机器周期,即24个振荡周期,因此外部输入的计数脉冲的最高频率为系统振荡器频率的1/24。5采用定时器/计数器T0对外部脉冲进行计数,每计数100个脉冲后,T0转为定时工作方式。定时1ms后,又转为计数工作方式,如此循环不止。假定AT89C51单片机的晶体振荡器的频率为6MHz,请使用方式1实现,要求编写程序。答:定时器/计数器T0在计数和定时工作完成后,均采用中断方式工作。除了第一次计数工作方式设置在主程序完成外,后面的定时或计数工作方式分别在中断程序完成,用一标志位识别下一轮定时器/计数器T0的工作方式。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:MOVTMOD,#06H;定时器/计数器T0为计数方式2MOVTL0,#156;计数100个脉冲的初值赋值MOVTH0,#156SETBGATE;打开计数门SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断CLRF0;设置下一轮定时方式的标志位WAIT:AJMPWAITIT0P:CLREA;CPU关中断JBF0,COUNT;F0=1,转计数方式设置MOVTMOD,#00H;定时器/计数器T0为定时方式0MOVTH0,#0FEH;定时1ms初值赋值MOVTL0,#0CHSETBEARETICOUNT:MOVTMOD,#06HMOVTL0,#156SETBEARETI6定时器/计数器的工作方式2有什么特点?适用于哪些应用场合?答:定时器/计数器的工作方式2具有自动恢复初值的特点,适用于精确定时,如波特率的产生。7编写程序,要求使用T0,采用方式2定时,在P1.0输出周期为400µs,占空比为101的矩形脉冲。答:根据题意,从P1.0输出的矩形脉冲的高低电平的时间为101,则高低电平的时间分别为363.63µs和36.37µs。如果系统采用6MHz晶振,Tcy=2µs,因此高低电平输出取整,则约为364µs和36µs。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:MOVTMOD,#02H;定时器/计数器T0为定时方式2MOVTL0,#4AH;定时364ms初值赋值SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断SETBP1.0WAIT:AJMPWAITIT0P:CLREACLRP1.0;关中断MOVR0,#9DLY:DJNZR0,DLY;延时36msMOVTL0,#4AH;定时364ms初值赋值SETBP1.0SETBEARETI8一个定时器的定时时间有限,如何用两个定时器的串行定时来实现较长时间的定时?答:方法1,在第一个定时器的中断程序里关闭本定时器的中断程序,设置和打开另一个定时器;在另一个定时器的中断程序中关闭本定时中断,设置和打开另一个定时器。这种方式的定时时间为两个定时器定时时间的和。方法2,一个作为定时器,在定时中断后产生一个外部计数脉冲(比如由P1.0接产生),另一个定时器工作在计数方式。这样两个定时器的定时时间为一个定时器的定时时间乘以另一个定时器的计数值。9当定时器T0用于方式3时,应该如何控制定时器T1的启动和关闭?答:由T1(P3.5)口控制定时器T1的启动和关闭。10定时器/计数器测量某正单脉冲的宽度,采用何种方式可得到最大量程?若时钟频率为6MHz,求允许测量的最大脉冲宽度是多少?答:采用方式1定时工作方式。最大脉冲宽度为131.072ms。11编写一段程序,功能要求:当P1.0引脚的电平正跳变时,对P1.1的输入脉冲进行计数;当P1.2引脚的电平负跳变时,停止计数,并将计数值写入R0、R1(高位存R1,低位存R0)。答:将P1.1的输入脉冲接入INT0,即使用T0计数器完成对P1.1口的脉冲计数。参考程序如下:ORG0000HLJMPMAINORG000BHLJMPIT0PMAIN:JNBP1.0,MAINMOVTMOD,#05H;定时器/计数器T0为计数方式1SETBTR0;启动T0,开始计数SETBET0;允许T0中断SETBEA;CPU开中断WAIT:JBP1.2,WAITCLREACLRTR0MOVR1,TH0MOVR0,TL0AJMP$IT0P:INCR2RETI12THx与TLx(x = 0,1)是普通寄存器还是计数器?其内容可以随时用指令更改吗?更改后的新值是立即刷新还是等当前计数器计满后才能刷新?答:THx与TLx(x=0,1)是由特殊功能寄存器构成的计数器,其内容可以随时用指令更改,更改后的新值立即刷新。但在读THx、TLx值时,应该先读THx值,后读TLx,再读THx值。若两次读得THx值相同,则可确定读得的内容正确。若前后两次读得的THx值有变化,再重复上述过程。第7章 AT89C51单片机的串行口1帧格式为1个起始位,8个数据位和1个停止位的异步串行通信方式是方式 。答:1。2在串行通信中,收发双方对波特率的设定应该是 的。答:相等。3下列选项中, 是正确的。A串行口通信的第9数据位的功能可由用户定义B发送数据的第9数据位的内容是在SCON寄存器的TB8位中预先准备好的C串行通信帧发送时,指令把TB8位的状态送入发送SBUF中D串行通信接收到的第9位数据送SCON寄存器的RB8中保存E串行口方式1的波特率是可变的,通过定时器/计数器T1的溢出率设定答:(A)对(B)对(C)错(D)对(E)对。4通过串行口发送或接收数据时,在程序中应使用 。AMOVC指令 BMOVX指令CMOV指令DXCHD指令答:(C)MOV指令。5串行口工作方式1的波特率是 。A固定的,为fosc/32B固定的,为fosc/16C可变的,通过定时器/计数器T1的溢出率设定D固定的,为fosc/64答:(C)。6在异步串行通信中,接收方是如何知道发送方开始发送数据的?答:当接收方检测到RXD引脚上的有效的负跳变时,即可知道发送方开始发送数据。7串行口有几种工作方式?有几种帧格式?各种工作方式的波特率如何确定?答:串行口有4种工作方式:方式0、方式1、方式2、方式3。 有3种帧格式,方式2和3具有相同的帧格式。 方式0的发送和接收都以fosc/12为固定波特率。 方式1的波特率=2SMOD/32×定时器T1的溢出率。 方式2的波特率=2SMOD/64×fosc。 方式3的波特率=2SMOD/32×定时器T1的溢出率。8假定串行口串行发送的字符格式为1个起始位、8个数据位、1个奇校验位、1个停止位,请画出传送字符“B”(42H)的帧格式。答:传送的字符“B”的帧格式如图所示(先低位后高位)。 起始位 0 1 0 0 0 0 1 0 校验位 停止位 图9为什么定时器/计数器T1用作串行口波特率发生器时,常采用方式2?若已知时钟频率、通信波特率,如何计算其初值?答:(1)因为定时器/计数器在方式2下,初值可以自动重装,这样在进行串口波特率发生器设置时,就避免了重装参数的操作,且减少了重装参数的误差。 (2)已知时钟频率、通信波特率,根据公式(7-3),即可计算出初值。10若晶体振荡器为11.0592MHz,串行口工作于方式1,波特率为4 800bit/s,写出用T1作为波特率发生器的方式控制字和计数初值。答:经计算,初值为FAH。控制字:ANL TMOD,#0F0HORLMOD,#20HMOVTH1,#0FAHMOVTL1,#0FAHMOVSCON,#40H11简述利用串行口进行多机通信的原理。答:以方式1为例。 发送过程:数据位由TXD端输出,发送1帧信息为10位,当CPU执行1条数据写发送缓冲器SBUF的指令,就启动发送。发送开始时,内部发送控制信号SEND变为有效,将起始位向TXD输出,此后,每经过1个TX时钟周期,便产生1个移位脉冲,并由TXD输出1个数据位。8位数据位全部输出完毕后,置1中断标志位TI,然后SEND信号失效。接收过程:当检测到起始位的负跳变时,则开始接收。接收时,定时控制信号有2种。其中一种是位检测器采样脉冲,它的频率是RX时钟的16倍。也就是在1位数据期间,有16个采样脉冲,以波特率的16倍速率采样RXD引脚状态,当采样到RXD端从1到0的跳变时就启动检测器,接收的值是3次连续采样,取其中2次相同的值,以确认是否是真正的起始位的开始,这样能较好地消除干扰引起的影响,以保证可靠无误地开始接收数据。12使用AT89C51的串行口按工作方式1进行串行数据通信,假定波特率为2 400bit/s,以中断方式传送数据,请编写全双工通信程序。答:请参考教材的P115-P117程序,并作适当改动。13某AT89C51单片机串行口,传送数据的帧格式由1个起始位(0)、7个数据位、1个偶校验和1个停止位(1)组成。当该串行口每分钟传送1 800个字符时,试计算出它的波特率。答:串口每秒钟传送的字符为1800/60=30个字符/秒,所以波特率为30个字符/秒×10位1个字符=300b/s。14为什么AT89C51单片机串行口的方式0帧格式没有起始位(0)和停止位(1)?答:串行口的方式0为同步移位寄存器输入/输出方式,常用于外接移位寄存器,以扩展并行I/O口,一般不用于两个89C51之间的串行通信。该方式以fosc/12的固定波特率从低位到高位发送或接收数据。15直接以TTL电平串行传输数据的方式有什么缺点?答:优点是连线简单,缺点是抗干扰性能差,传输距离短。第8章 AT89C51单片机扩展存储器的接口设计1单片机存储器的主要功能是存储 和 。答:程序,数据。2