机电一体化《单片机原理与应用》山东大学网络教育考试模拟题与问题详解

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《单片机原理及应用》
除非特别声明,编程题可以使用汇编语言编写,也可以使用 C 语言编写1、分析程序的执行结果,将结果填写到空格中。

ORG 0000H
MOV 30H,#50H
MOV R0,#30H
MOV A,@R0 ;(A= 50H )
MOV A,#79H
MOV B,#20H ;(A= 79H B= 20H )
DIV AB ;(A= 03H B= 19H )
PUSH B
MOV B,#0AH
MUL AB ;(A= 1EH B= 00H )
POP B
ADD A,B ;(A= 37H B= 19H )
MOV 30H,A ;(30H 单元的内容= 37H ) MOV
20H,30H
CLR 01H ;(20H 单元的内容= 37H )
MOV A,20H ;(PSW 中P的内容= 1 )
CPL A
RR A ;( PSW 中 C 的内容= 0 )
SWAP A ;(A= 46H )
ADDC A,#0F0H ;(A= 36H )
;(PSW 中P的内容= 0 )
;( PSW 中 C 的内容= 1 )
RL A ;(A= 6CH )
;(PSW 中P的内容= 0 )
;( PSW 中 C 的内容= 0 ) LOOP: AJMP LOOP
2、将MCS51 内部RAM60H ~65H 单元存放的12 个16 进制数变为ASCII 码,
放到0090H单元开始的外部RAM 中。

[使用汇编语言编写]
MAIN :
MOV R0,#60H
MOV R2,#6
MOV DPTR, #0090H
HASC: 标准
MOV A,@R0
ANL A,#0FH ;屏蔽高四位
ADD A,#0DH
MOVC A,@A+PC ;查表低四位转换为ASCII 码
MOVX @DPTR,A ;送如外部RAM
INC DPTR MOV
A,@R0
ANL A,#0F0H SWAP
A ADD A,#6
MOVC,@A+PC ;高四位转换为ASCII 码
MOVX @DPTR,A
INC R0
INC DPTR DJNZ
R2,HASC
END
ASCTAB:DB 30H 31H 32H 33H 34 H 35H 36H 37H 38H 39H
DB41H 42H 43H 44H 45H 46H
3、某一故障检测系统,当出现故障 1 时,线路1 上出现上升沿;当出现故障 2
时,线路2 上出现下降沿。

没有故障时,线路1 为低电平,线路2 为高电平。

出现故障时,相应的指示灯变亮。

故障消失后,指示灯熄灭。

试用MSC1211 为单片机实现该故障检测功能,画出电路原理图,并写出相应程序。

4、用MSC1211 的T0 定时/计数器,设计程序,实现在P1.0 输出周期为200ms
的占空比为1:1 的方波,输出500 个方波后停止输出。

解:ORG 0000H
LJMP MAIN
ORG 000BH ;T0 口中断服务程序入口地址
LJMP INT_T0
MAIN :MOV TMOD ,#00H ;T0 工作于方式0 定时
MOV TL0 ,#0CH
MOV TH0 ,#1EH ;设定秒中断周期为1ms
MOV A ,200 ;设定输出周期为200 ms
MOV R2,1000 ;输出500 个方波
SETB TR0
标准
SETB ET0
SETB EA
SETB P1.0
SJMP $
INT_T0 :MOV TL0 ,#0CH
MOV TH0 ,#1EH ;T0 重装时间常数
CPL P1.0 P1.0 位取反
DEC R2
JZ ENDP ;若R2 为0,则结束程序,否则返主程序继续输出
RETI ;返主程序
ENDP:END
5、利用MSC1211的A/D 构成数据采集系统。

使用模拟通道0 进行连续数据采
集,采集8 次后取得平均值,存放到预先分配好的100 个内存单元中,这100 个单元存满后,再从第一个单元进行覆盖保存。

写出完整的程序清单(应在适当的地方加程序注释)。

解:#include<REG1211.H>
#include<stdio.h>
extern void autobaud(void);// 声明外部函数
extern void bipolar(void);
float a[100]={0},w[8]={0};int out=0;long result,temp;int j;
int AUXinterrupts(void)interrupt6 using1// 中断服务程序
{
if(PAI==6) //处理AD 中断
{
w[out++]=bipolar();
temp=w[out];
SUMR0=temp&0xff;
SUMR1=(temp>>8)&0xff;
SUMR2=(temp>>16)&0xff;
SUMR3=(temp>>24)&0xff;
if(out==8)
{
SUM=SUMR3<<24+SUMR2<<16+SUMR1<<8+SUMR0;
}
SUM/=8;
a[j++]=SUM;
if(j>=100)
{j=0;}
}
}
min(void)
{
float dummy;
int decimation;
decimationg=1440;// 抽取因子
PDCON&=0x77 ;//打开ADC
ACLK=9 ;//模拟采样频率
ADMUX=0;// 使用通道0
ADCON0=0x30;// 内部基准 2.5V,缓冲器关,BOD 关,PGA=0
ADCON1=0x01;// 双极性,自动稳定模式,偏移增益自校准
ADCON2=decimation&0xff;// 写入抽取因子低字节
ADCON3= (decimation>>8 )&0x07;// 写入抽取因子高字节
AIE=&0x20;
autobaud();
//等待校准
for(i=0;i<4;i++)
{
while(!(AIE&0X20))
{
dummy=ADRESL;
}
SSCON=0;// 清除求和寄存器
EAI=1 ;
While(1);
}
}
6、变量k 从0 变到150,变化步长为10。

对于每一个值,使用整形数算术运算
计算8*k,k*k*k 和(40*k/150)^3。

这三个值通过MSC1211 的D/A 转换后同
步输出(均使用电压输出模式)。

试编写程序实现。

解:include<Reg1211.h>
data unsigned int k,j,i;
void main(void)
{
PDCON&=~0X48;
ADCON0=0X30;
DACSEL=6;
DACSEL=4;
DACL=0X24;
DACSEL=5;
DACH=0x24;
while(1)
{
DACSEL=0;DAC=0x8000;
for(j=0;j<100;j++)
DAC=0;
for(k=0;k<151;k+=10)
{
DACSEL=1;DAC=8*k;
DACSEL=2;DAC=k*k*k;
DACSEL=3;i=40*k/150;DAC=i*i*i;
DACSEL=6;DACL=0Xfc;
}
}
}
7、利用MSC1211 或8051 设计应答方式下的多机通讯程序。

通讯参数:晶振
为11.0592MHz,9600,n,8,1。

通讯过程如下:主机首先发送从机地址,
从机收到地址后进行比较,如果地址相符,则将从机地址回发给主机作为应答信号。

主机收到从机的地址应答信号后,将内存单元中的120 个数据发送给从机,并进行数据块校验(将各个数据进行异或),若校验正确,则从机发送00H 给主机,否则发送0FFH 给主机,主机重新发送数据。

(应在适当的地方加程序注释)
解:主机程序如下:
ORG 0000H
LJMP MAINT ;跳至主程序入口地址
ORG 0023H ;串行口中断服务程序入口
LJMP INTST
MAINT :MOV SCON,#90H ;置工作方式2,并允许接收
MOV TMOD ,#20H ;置T1 工作方式 2
MOV TH1 ,#0FDH
MOV TL1 ,#0FDH
MOV DPTR,#ADDR ;设置数据块首址ADDR 的地址指针
MOV R0,#120 ;设置发送字节数
MOV R1,#00H ;设置校验和的初值
MOV R2,#NAME
SETB TB8 ;置位TB8 位,作为发送地址桢信息特征
SETB TR1
SETB EA ;CPU 开中断
SETB ES ;允许串行口中断
MOV A ,R2 ;发送地址桢信息
MOV SBUF,A
SJMP $
;中断服务程序
INTST :MOV A ,TB8 ;判断是发送地址还是数据,若为数据则转LOOP0 CJNE A ,01H,LOOP0
CLR TI ;地址桢信息发送完后清发送中断
LOOP0:JB RI,LOOP1 ;检查是否是接受中断?若RI=1 则转入接受乙机发送应答信息
CLR TI ;因RI=0 ,表明是甲机发送中断数据的中断请求。

CPU 响应
中断,在中断服务程序中应清中断标志
MOV A ,TB8;
CJNE A ,#01H,LOO3 ;若为发送数据中断则转LOOP3 继续发送数据
LJMP ENDT ;甲机发送一数据完毕跳至中断返回程序
LOOP1 :CLR RI ;清接受中断标志
MOV A ,TB8 ;判断是发送地址还是数据,若为数据则转LOOP2
CJNE A ,#01H,LOOP4;若TB8 为0 则接受的为乙机数据校验应答
MOV A ,SBUF ;取乙机的应答数据
CJNE A ,@R2,LOOP2 ;若乙机应答信息不是从机地址,则地址传
送不正确,则转LOOP2 程序重新发送地址信息,否则清TB8,发送数据
CLR TB8
LOOP3 :MOVX A ,@DPTR ;取下一个数
MOV SBUF,A ;启动串行口,发送新的数据
XRL A ,@R1
MOV @R1,A
INC DPTR ;修改地址指针
DEC R0 ;修改发送字节数记数值
CJNE R0,#00H,ENDT ;判别120 个字节数据都发送完没有。

如果
没有发送完则跳至中断返回程序。

继续发送
MOV A ,@R1
MOV SBUF,A ;数据全部发送完毕则发送校验和
LJMP ENDT
LOOP4 :MOV A ,SBUF ;取乙机的应答数据
CJNE A ,#00H,LOOP5 ;若数据发送不正确,则转LOOP5 重
新发送
CLR ES ;全部发送完毕,禁止串行口中断
LOOP5:MOV DPTR,#ADDR ;设置数据块首址ADDR 的地址指针
MOV R0,#120 ;设置发送字节数
MOV R1,#00H ;设置校验和的初值
LJMP LOOP2
LOOP2 :MOV A ,R2 ;发送地址桢信息
MOV SBUF,A
RETI
ENDT :RETI
END
从机程序如下:
ORG 0000H
LJMP MAINR ;跳至主程序入口地址
ORG 0023H ;串行口中断服务程序入口
LJMP INTSR
MAINR :MOV SCON,#0B0H ;置工作方式2,并允许接收
MOV TMOD ,#20H ;置T1 工作方式 2
MOV TH1 ,#0FDH
MOV TL1 ,#0FDH
MOV DPTR,#ADDR ;设置数据块接收首址为ADDR
MOV R0,#120 ;设置接收字节数
MOV R2,#NAME
MOV R1,#00H ;设置校验和的初值
SETB RB8 ;置位RB8 位,作为接受地址信息特征
SETB TR1
SETB EA ;CPU 开中断
SETB ES ;允许串行口中断
SJMP $
;中断服务程序
INTSR :MOV A ,RB8 ;判断是接收地址还是数据,若为数据则转LOOP0 CJNE A ,01H,LOOP0
CLR RI ;地址桢信息接受完后清接收中断
MOV A ,SBUF
XRL A ,@R2
JZ LOOP ;若地址相符则转LOOP,否则中断返回
LJMP ENDR
LOOP:CLR SM2
CLR RB8
MOV A ,@R2
MOV SBUF,A ;想主机发送从机地址
LJMP ENDR
LOOP0:JB RI,LOOP1 ;检查是否是接受中断?若RI=1 则转入接受甲机发送的数据
CLR TI ;因RI=0 ,表明是乙机发送中断数据的中断请求。

CPU 响应
中断,在中断服务程序中应清中断标志
LJMP ENDR ;甲机发送一数据完毕跳至中断返回程序
LOOP1 :CLR RI ;清接受中断标志
DEC @R0
JZ LOOP2 ;数据未接收完则中断返回,若接收完则转LOOP2,校验
MOV A ,SBUF ;取甲机发送的数据
MOVX @DPTR ,A
XRL A,@R1
MOV @R1,A
LOOP2 :MOV A ,SBUF :取甲机发送的校验和
XRL A ,@R1
JZ RIGHT
LJMP WRONG
RIGHT :MOV A ,#00H
MOV SBUF,A
LJMP ENDR
WRONG :MOV A ,#0FFH
MOV SBUF,A
MOV DPTR,#ADDR ;设置数据块接收首址为ADDR
MOV R0,#120 ;设置接收字节数
LJMP ENDR
ENDR :RETI
END
《单片机原理及应用》
1、分析程序的执行结果,将结果填写到空格中。

ORG 0000H MOV
30H,#50H
MOV R0,#30H
MOV A,@R0 ;(A= 50H )
MOV A,#79H
MOV B,#20H ;(A= 79H B= 20H )
DIV AB ;(A= 03H B= 19H )
PUSH B
MOV B,#0AH
MUL AB ;(A= 1E B= 00H )
POP B
ADD A,B ;(A= 37H B= 19H )
MOV 30H,A ;(30H 单元的内容= 37H ) LOOP: AJMP LOOP
2、MCS51 内部RAM50H ~55H 单元存放的12 个16 进制数变为ASCII 码,放
到2800H 单元开始的外部RAM 中。

MAIN :
MOV R0,#50H
MOV R2,#6
MOV DPTR, #2800H
HASC:
MOV A,@R0
ANL A,#0FH ;屏蔽高四位ADD
A,#0DH
MOVC A,@A+PC ;查表低四位转换为ASCII 码
MOVX @DPTR,A ;送如外部RAM INC DPTR
MOV A,@R0
ANL A,#0F0H
SWAP A ADD
A,#6
MOVC,@A+PC ;高四位转换为ASCII 码
MOVX @DPTR,A
INC R0
标准
INC DPTR
DJNZ R2,HASC
END
ASCTAB:DB 30H 31H 32H 33H 34 H 35H 36H 37H 38H 39H
DB41H 42H 43H 44H 45H 46H
3、编制四个十六进制单字节数相加后求平均的程序。

假设4 个16 进制的单字节分别为a,b,c,d,计算结果方到 e 中
#include <reg51.h>
#define uchar unsigned char
void main(void)
{
uchar a,b,c,d,e;
e=(a+b+c+d)/4;
while(1);
}
4、用8031 的T0 定时/计数器,设计程序,实现在P1.0输出50ms 的方波,输
出100 个方波后停止输出。

#include <reg51.h>
#define uchar unsigned char
uchar a;
void main(void)
{
TMOD=0X01;
TL0=0XB0;
TH0=0X3C;
EA=1;
ET0=1;
TR0=1;
while(1)
{
if(a==100)
{
EA=0;
TR0=0;
}
}
}
void timer0(void) interrupt 1
{ TL0=0XB0;
TH0=0X3C; cpl
p1.0; a++;
}
5、甲单片机利用方式 1 将内部RAM30H ~37H 单元的ASCII 码发送到乙机。

编制甲机发送和乙机接收的程序(加奇校验)。

A 机发送程序设计
ST:
MOV TMOD,#20H MOV
TL1,#0E8H
MOV TH1,#0E8H SETB
TR1
MOV SCON ,#50H
MOV R0,#30H
MOV R1,#08H
LOOP:
MOV A,@R0
CALL FS
INC R0
DJNZ R1,LOOP
RET
FS:
MOV C,P
CPL C
MOV ACC.7,C
MOV SBUF A
WAIT:
JNB TI,WAIT
标准
CLR TI
RET
B 机的接受程序设计接受串口发来的程序,假设存放
在30H—37H 中
ST:
MOV TMOD,#20H
MOV TL1,#0E8H
MOV TH1,#0E8H
SETB TR1
MOV SCON ,#50H
MOV R0,#30H
MOV R1,#08H
LOOP: CALL
JS
JNC ERROR
MOV @R0,A INC
R0
DJNZ R1,LOOP
RET
ERROR:⋯⋯⋯;出错处理,如返回出错信息等R ET
JS:
JNB RI JS
CLR RI
MOV A, SBUF
MOV P C
ANL A,#7FH
RET
6、试用8031 和8155实现键盘和LED 动态显示。

画出原理示意图并编制键盘
扫描程序和LED 动态显示程序(16 个键的键盘扫描和 6 位LED 显示)。

键盘扫描子程序:
#include <reg51.h>
#include <intrins.h>
#define uchar unsigned char
标准
#define uint unsigned int
uchar num,i;
uint temp;
void main(void)
{
while(1)
{
keych();
}
}
void keych()
{
for(i=0;i<4;i++)
{
temp=0xfe;
temp= _crol_(temp, i);
P0=temp;
temp=P0;
temp=temp&0xf0;
if(temp!=0xf0)
{ delay();
if((P0&0xf0)!=0xf0)
{
switch(temp)
{
case 0x70:
jpch;
break;
case 0xb0:
jpch;
break;
case 0xd0:
jpch;
break;
case 0xe0:
jpch;
break;
}
}
}
}
}
Void jpch(void)
{
⋯..//按键扫描处理程序
}
LED 动态扫描子程序
假设各端口都已初始化
#include <reg51.h>
Unsigned char duanx[]={0x3f,0x06,0x5b,0x4f,0x66,0xbd}
Unsigned char weix[]={0x80,0x40,0x20,0x10,0x80,0x40}
Void main(void)
Init();// 初始化各端口
P1=0
While(1)
{
Unsigned char ;
For (i=0;i<6,i++)
{
P0=duanx[i];
P1++ P0=weix[i];
Delay();
P1=0;
P0=0;
}
i=0;
p1=0
}
5、利用8031 和8 位A/D(ADC0809)构成数据采集系统。

每隔20ms采集通
道0 的一次数据,将采集的数据存放在30H 的内部RAM 中。

画出原理示意图,写出较完整的程序清单。

(提示:需要用定时器和外部中断)。

《单片机原理及应用》
一、分析程序的执行结果,将结果填写到空格中。

1、MOV 40H,#80H
MOV R0,#40H
MOV A,@R0 ;(A= 80H )
MOV B,#20H
DIV AB ;(A= 04H B= 00H )
MOV @R0,A ;最终结果存于内存单元40H 中。

2、MOV A,#2AH
RR A MOV
B,A
MUL AB ;(A= B9H B= 01H )
(OV= 1 CY= 0 )
3、MOV A,#0B2H
MOV R1,#055H
ANL A,R1 ;(A= 10H )
ORL A,R1 ;(A= 55H )XRL
A,R1 ;(A= 00H )
SWAP A ;(A= 00H )
4、设内存20H 的内容为30H,30H 的内容为46H,46H 的内容为57H
MOV R0,#30H
MOV A,@R0 ;(PSW 中P的内容= 1 )
XCH A,R0
ADD A,#0DBH
SUBB A,#74H ;(A= 96H )
;(PSW 中P的内容= 0 )
;( PSW 中 C 的内容= 0 )
5、MOV 25H,#39H
CLR 2AH ;(25H)=(00111001 B)
CPL 2CH ;(25H)=(00101001 B)
SETB 2EH ;(25H)=(01101001 B)
MOV C,28H ;( PSW 中C 的内容= 1 )
二、程序设计
1、MCS51 内部RAM 40H~60H 单元存放着有符号16 进制数,将其中能被 2 整除的数,存放到0090H 单元开始的外部RAM 中。

[使用汇编语言编写]
解:ORG 0000H
JMP START
START:MOV SP,#60H
MOV DPTR,#0090H
MOV R0,#40H
MOV R1,#21
LOOP0 :MOV A ,@R0
MOV B, #2
DIV AB
MOV R2, B
CJNZ R2, #0, LOOP1 ; 余数为0 则继续,不为0 则转移
MOV A,@R0
MOV @DPTR,A
INC DPTR
LOOP1: INC R0
DJNZ R1, LOOP0
END
2、用MSC1211 的T1 定时/计数器,定时0.1S中断,使P1 口的8 个发光二极管每隔1S 循环点亮。

设系统主频为6MHZ。

LJMP T1-ISR 标准
ORG 0100H
MAIN :MOV SP,#60H ;设置堆栈指针
MOV P1,#01H ;设置P1.1 发光
MOV TMOD ,#10H ;T1 初始化
MOV TL1 ,#B0H
MOV TH1 ,#3CH
SETB TR1 ;启动T0 计数
SETB ET1 ;允许T0 中断
SETB EA ;CPU 开中断
SJMP $ ;等待
T1_ISR:MOV TL1,#B0H
MOV TH1,#3CH
MOV A,P1 ;P1 口循环左移
RL A
MOV P1,A
EXIT: RETI
END
3、设有甲、乙两台单片机,以工作方式 3 进行串行通讯,设晶振为11.0592MHz,
波特率为9600,甲机将内存单元中的120个数据作补偶校验后发送给乙机,乙
机对接收到的数据进行奇偶校验,若校验正确,则从机发送00H 给甲机,甲机继续发送数据,校验不正确,则发送0FFH 给甲机,甲机重新发送原数据,编写乙机的接收程序。

(应在适当的地方加程序注释)
解:ORG 0000H
AJMP MAIN
ORG 0023H
LJMP SE2_INT
MAIN:
MOV SP,#60H
MOV TMOD #20H
MOV TH1,#0FDH ; 设置波特率为9600bps
MOV TL1,#0FDH
MOV SCON,#90H ; 串行口工作方式3,允许接收
SETB EA
SETB ES
SJMP $ ;等待接收中断
SE2_INT:
JB RI,LOOPA
CLR T1
LJMP ENDR
LOOPA :CLR RI
MOV A,SBUF
MOV C,P ;奇偶校验
JC LOOP1 ;如8位数是奇,则转LOOP1 再检测RB8位
ORL C,RB8 ; 如8位数为偶,再检测RB8位,RB8=1, 则9位数据为奇,补偶
JC LOOP2 ;错,转LOOP2
LJMP LOOP3 ; 补偶正确,转LOOP3
LOOP1: ANL C, RB8 ;8位数为奇,再检测RB8 位
JC LOOP3 ;RB8=1, 补偶正确,转LOOP3
LOOP2: MOV A ,#0FFH ; 检测不正确发送FF给甲机
MOV SBUF,A
JMP ENDR
LOOP3 :MOVX @DPTR ,A
MOV A,#00H
MOV SBUF,A
INC DPTR
DJNZ R1, ENDR
CLR ES ; 停止接收
ENDR: RETI
2、某一故障检测系统,当出现故障时,线路出现下降沿;没有故障时,线路为高电平。

出现故障时,相应的指示灯变亮。

故障消失后,指示灯熄灭。

试用MSC1211为单片机实现该故障检测功能,画出电路原理图,并写出相应程序。

4、变量k 从20 变到200,变化步长为20。

对于每一个值,使用整形数算术运
算计算8*k,k*k*k 和(40*k/150)^3。

这三个值通过MSC1211 的D/A 转换后
同步输出(均使用电压输出模式)。

试编写程序实现。

解:#include 〈Reg1211.h〉
data unsigned int i , j ;
void main (void)
{
PDCON &=0x37 ; //同时开启ADC 和DAC 模块
ADCON0 =0x30 ; //内部参考电压 2.5V
DACSEL =6; //选择将要访问DAC 加载寄存器LOADCON
DACL = 0XFC ; //设置DAC1 、2、3 通道同步更新模式
DACSEL = 4; //选择DAC0 、1 控制寄存器
DACL =0x24; //DAC IDAC 关闭,内部参考电压
DACH =0x24; //DAC1 IDAC 关闭,内部参考电压
DACSEL=5; //选择DAC2 、3 控制寄存器
DACL =0x24 ; //DAC2 IDAC 关闭,内部参考电压
DACH=0x24; //DAC3 IDAC 关闭,内部参考电压
while (1)
{
DACSEL = 0; //选择DAC1 数据寄存器
DAC = 0x8000 ;//送DAC1 要转换的数据
for (j=0 ; j <100 ; j++ ) ;// 延时
DAC =0 ;
for (i=20 ; i<200 ; i+=20 ) ;
{
DACSEL = 1;
DAC = 8*k ;
DACSEL =2 ;
DAC = k*k*k ;
DECSEL = 3;
j = 40*k/150 ;
j = j^3 ;
DACSEL = 6 ;
DACL = 0XFC ;
}
}
}。

相关文档
最新文档