#半小时速通单片机 # 单片机复习资料 - 无答案 -挖空版 #背题

单片机复习资料-挖空

选择(20)、简答(40)、程序填空(30)、设计(10)

整理人: 张鹏

一. 选择题

  1. C语言中最简单的数据类型包括 ()

  2. 51单片机时序单位从 () 到() 是

    2()—>1状态

    6状态—>机器周期

    1—4机器周期—> ( )

  3. 七段共阴极数码管显示字符‘A’,’H’,’L’,段码应为( )。
    在这里插入图片描述

  4. MCS-51单片机内部有 ( ) 个16位定时器/计数器。

  5. 单片机程序存储器的寻址范围是由程序计数器 ( ) 的位数决定的,MCS-51的PC为 ( ) 位,其寻址范围是 ( ) 。

  6. 控制串行口工作方式的寄存器是( )。

  7. 定时器工作方式的寄存器是( )。

  8. 在51单片机单片机中断 ()

    INT0 ()

    T0 ()

    INT1 ()

    T1 ()

    串口 ()

  9. 定时器/计数器工作 ( ) 是13位计数结构

( ) 是16位计数结构。

( )是8位计数器结构

( ) 是2个8位计数器结构( ()

  1. 在单片机中, ( ) 片内数据存储器

() 片外数据存储器

( ) 程序存储器

  1. 51单片机串行口有4种工作方式

  2. MCS-51单片机复位操作的主要功能是把PC初始化为 ()

  3. INTEL 8051 CPU是 () 位的单片机。

  4. 定时器 ( )的启动位是 TR0\TR1

  5. 在单片机中,( ) 是数据存储器。( )是程序存储器

  6. MCS-51单片机有片内 ( ) ROM、( ) RAM

  7. 51单片机的对应的中断号

  8. 51单片机的对应的中断号优先级

    INT0 -> T0 -> INT1 -> T1 -> 串口

    MCS-51能够响应定时器T0中断、外部NT1中断,它的中断允许寄存器IE的内容应是

    EA//ESET1EX1ET0EX0
    10000110

二、简答题

  1. 8051有哪几 () 个中断源?每个中断对应的 中断标志 是什么?写每个中断对应的中断类型号是多少?

  2. MCS—51的存储器空间从逻辑上可以分为那 3几个空间?每个空间的空间有多大?MCS—51的存储器空间从物理上可以分 4为那几个空间?

  3. 51单片机的定时器工作模式有几种?

  4. 定时器的不同工作模式有什么特征?

  5. 如何设置定时器的工作模式?

  6. 51单片机有几个定时器/计数器?

  7. 如何计数的?

  8. 定时器和计数器什么区别?如何选择?

  9. 在单片机庄频6MHZ和12MHZ计数的时钟脉冲频率f和周期T?

  10. 在单片机主频6MHZ和12MHZ,定时10ms,定时计数值是多少?如何设置时间常数X? 如何知道定时时间到了?

  11. 串行通信中,单片机的fosc=12MHz,串口波特率为1400,串口工作在方式1。用C51写出初始化过程。(SCON格式如下)

D7D6D5D4D3D2D1D0
SM0SM1SM2RENTB8RB8TIRI
  1. 写出单片机串行口发送 接收数据的过程(中断法)?
  2. 如何确定时器的中断子程序?
  3. 在主程序中,使用定时器0工作在方式1采用中断,需要那些语句?
  4. 51单片机的异步串行口中,有几个串行数据缓冲器SBUF?
  5. 如何区分他们?
  6. 串口控制寄存器是什么?
  7. 串行口有4种工作方式?

三、程序填空

unsigned char code key_table[] = 
{
    0xee,0xde,0xbe,0x7e,
    0xed,0xdd,0xbd,0x7d,
    0xeb,0xdb,0xbb,0x7b,
    0xe7,0xd7,0xb7,0x77
};
char getKey(void)
{
   unsigned char i,tmpcode;
   P3 = 0xf0;             // 发送全0行扫描码
   if( ( P3&0xf0 ) != 0xf0){   //若有按键按下
       dealay(10);				//延时去抖动
       if( ( P3&0xf0 ) != 0xf0){	//延时后再判断一次,去除抖动
           for(int i=0;i<4;i++){
               P3 = scancode[i];		//输出行扫描码
               if( ( p3&0xf0 ) != 0xf0){  //本行有键按下
                   tmpcode = P3;		 // 返回特征字节码
                   while(( P3&0xf0 ) != 0xf0);
                   return (tmpcode)
               }
           }
       }
   }
   return (0); //无键按下,返回值为0
}
time0() interrupt 1
{
    count++;
    if(count==1000){
        count = 0;
        state++;
        if(state==8){
            state=0;
            LED=0xfe;
        }else{
            LED=(LED<<1)|0x01;
        }
        P1=LED;
    }
    TH0=(65536-1000)/256;
    TH0=(65536-1000)%256;
}

a) 计数显示器,对按键动作进行统计,并将动作次数通过数码管显示出来(参考如下电路图)。

#include <reg51.h>
// led_mode存放的是LED显示码
unsigned char code led_mode[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
unsigned char code led_p[]={0xfe,0xfd,0xfb,0xf7}; //LED位选
unsigned char data d[4]={0,0,0,0},count=0;
unsigned char j=0;
TIMER0() interrupt 1  //此语句中的1定时0   
{  
    P0=0;  	
	P0=led_mode[d[j]];    
	P2= led_p[j];
	j=(j+1)%4;                 
	TH0=(65536-1000)/256; 
	TL0=(65536-1000)%256;
}
INT_0() interrupt 0 sing 2    
{  	
    count++;                  
    if(count==100) count=0 ;
    d[2]= count/10;
    d[3]=count%10;
}
main()
{  
   TMOD=0x01; 
   TH0=(65536-1000)/256; 
   TL0=(65536-1000)%256;
   EA=1;                     
   EX0=1;                   
   IT0=1;                    
   TR0=1;                     
   while(1);
}

b) 采用定时器中断方式使P1口上的8个LED灯每间隔10ms轮流点亮(如下图所示)

image-20230613214645050
#include <reg51.h>
unsigned char n=0,i=0;
unsigned char code ledcod[]={0x7f, 0xbf,0x0df,0x0ef,0x0f7,0x0fb,0x0fd,0x0fe,0x0ff};
void TIMER(void) interrupt  1 using 2  
{  
    TH0=(65536-1000)/256;   
	TL0=(65536-1000)%256;
    n++;
    if(n>10){
       	n=0 ;
 		i=(i+1)%8;
    }
	P1=ledcod[i]
}
main()
{    
    TMOD=0x01;  
	TH0=(65536-1000)/256;
    TL0=(65536-1000)%256;
    EA=1;
    ET0=1;
    TR0=1;
    while(1); 
}

计数显示器,对按键动作进行统计,并将动作次数通过数码管显示出来(参考如下电路图)

#include <reg51.h>
unsigned char code led_mod[]={0x3f,0x06,0x5b,0x4f,0x66, 0x6d,0x7d, 0x07,0x7f,0x6f,0x00};//0X00标红
unsigned char code led_sca[]={0xfe,0xfd,0xfb,0xf7};
unsigned char led_data[]={10,10,10,10};//此语句中的10 去LED显示码得到00,数码管不亮  //10,10,10,10标红    
unsigned char count;
void delay(unsigned int time)
{ 
    unsiged int i;
    for(i=0;i<time;i++);
}
void led_disp()
{ 
   unsigned char i,j;
   for(i=0;i<4;i++){
       P0=0x00;
       j=led_data[i];
       P0=led_mod[j];
       P2=led_sca[i];
       delay(1000);
   }
}
int1() interrupt 2  //此语句中的2代表 对应中断INT1   
{   
    count=(count+1)%100;
    led_data[2]=count/10;
    led_datal3l=count%10}
main()
{ 
 	led_data[2]=count/10;
 	led_data[3]=count*10;
	IT0=1;         //此语句作用是设置边沿触发
	EX0=1;        //此语句作用是允许INT0中断
	EA=1;         //此语句作用是CPU开中断
	while(1) led_disp();
}

2)利用定时器1ms中断一次,动态显示LED的原理,将8756显示在4位数码管上(参考如下电路图)

13
#include <reg51.h>
//led_mode[]中存放的是数码管的显示码 
unsigned char code led_mode[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};  
unsigned char code led_p[]={0xfe,0xfd,0xfb,0xf7};
unsigned char data d[4]={8756}; //8,7,5,6 标红
unsigned char j=0;
TIMER0() interrupt 1 using 2  
{  
    P0=0;
	P0=led_mode[d[j]];  
    P2=led_p[j];              
    j=(j+1)%4;
    TH0=(65536-1000)/256; 
	TL0=(65536-1000)%256;
}
main()
{  TMOD=0x01; 
   TH0=(65536-1000)/256; 
   TL0=(65536-1000)%256;
   EA=1;
   ET0=1;
   TR0=1;
   while(1);
}

14

#include <reg51.h>
unsigned char count=0;
sbit start=P2^7;
bit flag=0;
void TIME0() interrupt 1
{ 
  TH0=(65556-10000)/256;
  TL0=(65556-10000)%256;
  count++;
  if(count==20){
     count=0;
	 flag=1;
  }
} 
main()
{ 
  unsigned char n,LED;
  TMOD=0x01;
  TH0=(65556-10000)/256;
  TL0=(65556-10000)%256;
  TR0=1;
  ET0=1;
  EA=1;
  SCON=0;
  n=0;
  LED=0x7f;
  start=1;
  while(1){
    if(flag==1){
       flag=0;
	   SBUF=LED;
	   while(!TI);	//等待发送结束
	   TI=0;
	   n++;
	   if(n==8){
	       n=0;
           LED=0x7f;
		}else{
          LED=(LED>>1)|0x80;  
        }
    }
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是阿鹏啊~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值