目录
0x00 前言
- 抄袭是一种获取,是刹那间的的错觉。获取而进行理解,错觉才能凝聚记忆海洋。 --涂寐
0x01 十六进制编码
数字 | 十六进制编码 | 数字 | 十六进制编码 | |
0 | 0x03 | 8 | 0x01 | |
1 | 0x9F | 9 | 0x09 | |
2 | 0x25 | A | 0x11 | |
3 | 0x0D | B | 0xC1 | |
4 | 0x99 | C | 0x63 | |
5 | 0x49 | D | 0x85 | |
6 | 0x41 | E | 0x61 | |
7 | 0x1F | F | 0x71 |
数字 | 十六进制编码 | 数字 | 十六进制编码 |
0 | 0x3F | 8 | 0x7F |
1 | 0x06 | 9 | 0x6F |
2 | 0x5B | A | 0x77 |
3 | 0x4F | B | 0x7C |
4 | 0x66 | C | 0x39 |
5 | 0x6D | D | 0x5E |
6 | 0x7D | E | 0x79 |
7 | 0x07 | F | 0x71 |
0x02 题目与解题
一、题目
- 选用定时/计数器T0,工作方式1,每隔50ms计数
- 选用定时/计数器T1,工作方式1,每隔1s计数
- 仿真原理图:
元器件 | 快捷 | 元器件 | 快捷 |
单片机 | AT899C51 | 电容 | cap |
电阻 | res | 电解电容 | cap- |
数码管 | 7seg | 晶振 | cry |
二、解题
1、步骤理解
1. 设定T0为工作方式1
TMOD = 0x01;
//即TMOD = 0000 0001B,
//没用到T1,则高四位直接用0表示,
//低四位GATE=0(门控制位,置0,不受外部中断影响)
//C/T=0(定时器模式,不用外接),M1M0=01(使用工作方式1,即16位定时器);
2. 设定定时器T0初值
//设定定时器初值,晶振粗略为12MHz,经12分频,则f=12/12=1MHz,故周期T=1/f=1us
//又需要亮50ms,则计数值N=50*1000*T=50000us
//则计数初值X=2^16-N=65536-50000=15536us
//定时器T0高八位赋值:TH0=X/2^8=(2^16-N)/256=15536/256
//定时器T0低八位赋值:TH0=X%2^8=(2^16-N)%256=15536%256
3. 查询方式
//查询方式-->不断查询溢出标志位TF0是否为1,为1则时间到
TR0=1;
2、正式解题
1.选用定时/计数器T0,工作方式1,每隔50ms计数
#include <reg51.h>
//要求:选用定时/计数器T0(只用寄存器TMOD的低四位),工作方式1(16位定时器),每隔50ms计数
unsigned char num[10]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F}; //全局表链,数码管共阴极
unsigned char count=0; //临时变量,存储下标
void main(){
TMOD=0x01; //定时器、工作方式1
//T0的高八位和低八位设定
//计数初值:X=2^n-N;此时,n=16(定时器的位数)
//计数值:N=time/(f0/12),此时time50ms(单位必须转成us),f0为单片机晶振频率,12为12分频
TH0=(65536-50000)/256; //处256,即右移8位(2^8=256)取得高四位
TL0=(65536-50000)%256; //求余,取得低四位
TR0=1; //开启定时器
P2=num[count]; //使用P2口连接数码管
while(1){
while(TF0==0); //溢出标志位为1时,才执行下面代码
TF0=0; //溢出标志位清0
//改变P2口的值;求余?举个栗子:若count=10,则10%10=0;可以减少一个if判断
P2=num[++count%10];
//为高八位和低八位重新赋予初值
TH0=(65536-50000)/256;
TH0=(65536-50000)%256;
}
}
2.选用定时/计数器T1,工作方式1,每隔1s计数
#include <reg51.h>
//要求:选用定时/计数器T1(只用寄存器TMOD的高四位),工作方式1(16位定时器),每隔1s计数
unsigned char num[10]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
unsigned char count=0,time=19; 因为time先使用,再自增,所以time应为19,而不是20
void main(){
TMOD=0x10; //0001 0000
TH1=(65536-50000)/256;
TL1=(65536-50000)%256;
TR1=1;
P2=num[count];
while(1){
while(TF1==0); //1s(20*50ms=20*50000us)?超范围(>65535)
TF1=0;
if(!time--){ //判断,即先让扫描20次,每次50000us,当达到1s时,再改变P2口的值
P2=num[++count%10];
time=19;
}
TH1=(65536-50000)/256;
TH1=(65536-50000)%256;
}
}
0x03 总结
- 抄袭是一种获取,是刹那间的的错觉。获取而进行理解,错觉才能凝聚记忆海洋。 --涂寐