单片机的查表程序
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
在单片机开发过程中、一些非线性得控制过程、最适合做一个表格来、时时改变系统得参数、达到控制得目得、最常得如产生正弦得得程、就就是建一个大得数组时时改变输出得8位字节送给外部DA、由DA 生成一个完整得正弦波、当然了、LED显示也就是一个例子、通过建一个数组来实现段码得点亮点灭、下面就就是一个LED表-—-digits[0]
#define SEG_a 0x01
#define SEG_b 0x02
#define SEG_c 0x04
#define SEG_d 0x08
#define SEG_e 0x10ﻫ#defineSEG_f 0x20ﻫ#define SEG_g 0x40
#defineSEG_dot 0x80ﻫunsigned char digits[10]={
(SEG_a|SEG_b|SEG_c|SEG_d|SEG_e|SEG_f),//0
(SEG_b|SEG_c), //1
(SEG_a|SEG_b|SEG_d|SEG_e|SEG_g), //2ﻫ (SEG_a|SEG_b|SEG_c|SEG_d|SEG_g), //3
(SEG_b|SEG_c|SEG_c|SEG_f|SEG_g), // 4ﻫ (SEG_a|SEG_c|SEG_d|SEG_f| SEG_g), // 5ﻫ (SEG_a|SEG_c|SEG_d|SEG_e|SEG_f|SEG_g), //6ﻫ (SEG_a|SEG_b|SEG_c), // 7
(SEG_a|SEG_b|SEG_c|SEG_d|SEG_e|SEG_f|SEG_g), // 8
(SEG_a|SEG_b|SEG_c|SEG_d|SEG_f|SEG_g) // 9ﻫ };
C查表就太简单了temp2= digits[ show_data[i]];一句搞定,C中还有一个switch 语句也就是一个很好得用查表语句
C51汇编就相对麻烦一点、不过MCS—51指令系统中有专用得查表指令:MOVC A,A+DPTR与M OV A,A+PC、
MOVC A,A+DPTR指令,DPTR作为基址寄存器时,其值为16位而且可根据需要设计,故可用于在64KROM范围内查表。编写查表程序时,首先把表得首址送入DPTR中,再将要查找得数据序号(或下表值)送入A中,然后就可以使用该指令进行查表操作,并将结果送累加器A中。
MOVCA,A+PC指令,PC作为基址寄存器时,其值由指令得位置确定,它只能设在查表指令操作码下得256个字节范围内。编写查表程序时,首先把查表数据得序号送入A中,再把从查表指令到表得首地址间得偏移量与A值相加,然后使用该指令进行查表操作,并把结果送累加器A中。
下面就是把内部RAM 30H-37H单元中得十六进制数依次转换为ASCII码,并存入内部RAM60H-6FH单元之中。用查表法编写程序.
分析:由于十六进制数就是从0~F,对应得ASCII码为30H~46H,每一个单元存放得16进制数,转
换为ASCII码后分别存入2个单元,低位存低地址,高位存高地址。用ANL A ,#0FH分别取高4位与低4位。进行查表转换成相应得ASCII码。
MOVC A,A+DPTR 程序如下:ﻫORG 0000H
AJMP MAININITIAL
ORG 0050H
MAININITIAL:;给30H—37H赋初值ﻫMOVR0,#30H;设置存数指针R0初值
MOV R1,#00H ;设置赋值变量个数计数寄存器R1(循环计数器)初值
MOV DPTR,#initialtab
NEXTINITIAL:
MOVA,R1
MOVCA,A+DPTR ;查表数据送累加器A ﻫMOVR0,A
INC R0 ;指针增一ﻫINC R1;循环计数器增一
CJNER1,#8,NEXTINITIAL ;判给30H-3FH赋初值完否
MAIN:ﻫMOVR0,#30H;设置十六进制数地址指针
MOV R1,#60H ;设置ASCII码地址指针
MOV R7,#08H;需拼装得十六进制数字节个数
MOVDPTR,#ACSIITAB ﻫABC:
MOVA,R0;取十六进制数ﻫMOVB,A ;暂存
ANL A,#0F0H ;取十六进制数得字节高4位ﻫRR A ;取十六进制数得字节高4位移到字节得低4位
RR A
RRA ﻫRRA
MOVC A,A+DPTR ;查表数据送累加器A ﻫMOV R1,A ;保存转换结果ﻫINC R1 ;转换结果指针增一ﻫMOVA,B ﻫANL A,#0FH ;取十六进制数得字节低4位ﻫMOVCA,A+DPTR ;查表数据送累加器A
MOV R1,A ;保存转换结果
INCR1 ;转换结果指针增一
INC R0 ;转换数据指针增一ﻫDJNZ R7,ABC ;继续ﻫSJMP$
initialtab: ;给30H—37H赋值用初值表ﻫDB23H,6DH,09H,7FH,8CH,1EH,4BH,5AH
ACSIITAB: ;0~F,对应得ASCII码表
DB"012345678"ﻫDB ”9ABCDEF”
END
MOVC A,A+PC程序如下: ﻫORG 0000H ﻫAJMP MAININITIAL
ORG0050H
MAININITIAL:;给30H-37H赋初值
MOV R0,#30H ;设置存数指针R0初值
MOV R1,#00H;设置赋值变量个数计数寄存器R1(循环计数器)初值ﻫMOVDPTR,#initialtabﻫNEXTINITIAL:
MOV A,R1ﻫMOVC A,A+DPTR;查表数据送累加器A ﻫMOV R0,A ﻫINCR0 ;指针增一ﻫINC R1 ;循环计数器增一ﻫCJNER1,#8,NEXTINITIAL ;判给30H—3FH赋初值完否ﻫMAIN:
MOVR0,#30H ;设置十六进制数地址指针
MOVR1,#60H;设置ASCII码地址指针ﻫMOV R7,#08H;需拼装得十六进制数字节个数MOV DPTR,#ACSIITAB
ABC:ﻫMOV A,R0;取十六进制数
MOV B,A ;暂存
ANL A,#0F0H;取十六进制数得字节高4位ﻫRRA;取十六进制数得字节高4位移到字节得低4位
RR A
RR A
RR A
ACALL TRANACSAII ;查表数据送累加器A ﻫMOV R1,A;保存转换结果
INCR1;转换结果指针增一
MOV A,B
ANL A,#0FH ;取十六进制数得字节低4位ﻫACALL TRANACSAII ;查表数据送累加器AﻫM OV R1,A;保存转换结果
INC R1 ;转换结果指针增一
INC R0;转换数据指针增一ﻫDJNZ R7,ABC ;继续ﻫSJMP $
initialtab: ;给30H-37H赋值用初值表ﻫDB23H,6DH,09H,7FH,8CH,1EH,4BH,5A H
TRANACSAII: ﻫINC A;查表之前A加1就是因为MOVC指令与数据表之间有一个地址单元得间隔(RET指令) ﻫMOVC A,A+PC;由于数据表紧跟MOVC指令之后,因此以PC作为基址寄存器比较方便、
RET
ACSIITAB: ;0~F,对应得ASCII码表ﻫDB"012345678" ﻫDB "9ABCDEF”
end