(转)单片机高级裸机编程(一)-- 数据驱动程序

我理解的所谓数据驱动程序的方法,简单而言:将数据与程序分析,将代码逻辑的组织转换成数字规律的统计。即将数据作为一个要处理的脚本(当做数据库),然后程序作为解释器,将脚本的内容用代码逻辑解释出来,实现编程功能。

这就要求我们将代码逻辑分解出其内在数据关系,这样我们就可以写出与数据无关的函数,这样的函数通用性很大,利于复用,耦合性也比较低,利于修改,且修改后不易出错。

这样的方法也有坏处,就是可读性变差,解决的办法就是多写点关于逻辑的注释。

下面举个例子:(来自书籍–单片机编程魔法师之高级裸编程思想,挺好的一本书,可以看看,可以去下载下载链接处,待有缘人! )

(1)要实现如下波形:
在这里插入图片描述
(2)我们 一般的实现方法:将上面分成16段(依据是波形存在不一样的时候作为分界点),每段单独分析。代码如下(使用51单片机实现)

#include <reg51.h>
 
sbit P10=P1^0;
sbit P11=P1^1;
sbit P12=P1^2;
sbit P13=P1^3;
 
void delay(unsigned char d, unsigned int t)
{
	unsigned int i;
 
	P1 = P1 & 0xF0 | d;
	for(i=0; i<t; i++);
}
 
main(void)
{
	while(1)
	{
		delay(0x00, 749);		// 阶段1
		delay(0x01, 251);		// 阶段2
 
		delay(0x00, 749);		// 阶段3
		delay(0x03, 251);		// 阶段4
 
		delay(0x00, 749);		// 阶段5
		delay(0x01, 251);		// 阶段6
 
		delay(0x00, 749);		// 阶段7
		delay(0x07, 251);		// 阶段8
 
		delay(0x00, 749);		// 阶段9
		delay(0x01, 251);		// 阶段10
 
		delay(0x00, 749);		// 論僇11
		delay(0x03, 251);		// 論僇12
 
		delay(0x00, 749);		// 阶段13
		delay(0x01, 251);		// 阶段14
 
		delay(0x00, 749);		// 阶段15
		delay(0x0F, 251);		// 阶段16
	}
}

(3)而采用数据驱动程序的方法:将每个阶段分离出数据,然后用一个函数统一处理。本例中使用数组来存储代表各个阶段的逻辑的数据,接着用一段代码就可解决,来代码如下:

#include <reg51.h>
 
sbit P10=P1^0;
sbit P11=P1^1;
sbit P12=P1^2;
sbit P13=P1^3;
 
#define STAGES		16
unsigned char code P1_1234[] = {0, 1, 0, 3, 0, 1, 0, 7, 0, 1, 0, 3, 0, 1, 0, 15};
unsigned int code Dts[] = {749, 251, 749, 251, 749, 251, 749, 251, 749, 251, 749, 251, 749, 251, 749, 251};
 
void delay(unsigned char d, unsigned int t)
{
	unsigned int i;
 
	P1 = P1 & 0xF0 | d;
	for(i=0; i<t; i++);
}
 
main(void)
{
	int i;
 
	while(1)
	{
		for(i=0; i<STAGES; i++)
			delay(P1_1234[i], Dts[i]);
	}
}

(4)好处:似乎没有看出了,牺牲了易读性,有得必有失,我们会的得到什么?

再举几个例子:实现以下波形。对于这个波形,如果我们不采用数据驱动程序的方法,那么相当于重写(重新分阶段,不难但是繁琐),而使用这种高阶的方法后,解释器代码一个字母都不用改变。
在这里插入图片描述
数据驱动程序的代码如下:

#include <reg51.h>
 
sbit P10=P1^0;
sbit P11=P1^1;
sbit P12=P1^2;
sbit P13=P1^3;
 
#define STAGES		8
unsigned char code P1_1234[] = {0, 1, 3, 7, 15, 7, 3, 1};
 
void delay(unsigned char d, unsigned int t)
{
	unsigned int i;
 
	P1 = P1 & 0xF0 | d;
	for(i=0; i<t; i++);
}
 
main(void)
{
	int i;
 
	while(1)
	{
		for(i=0; i<STAGES; i++)
			delay(P1_1234[i], 500);
	}
}

(5)总结:

虽然数据驱动代码这种高阶的方法不是万能,但是对于相似的编程要求,则给我们提供了一种可复用的方法,避免一些简单却繁琐的工作任务。

还有, 用这种方法记得写注释,不然不仅别人看不懂, 就连几天后的你再次回顾时,都不知道是怎么写出来的。@TOC


转载原文:https://eureka1024.blog.csdn.net/article/details/83447957

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值