单片机的查表程序

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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

相关文档
最新文档