C語(yǔ)言在單片機開(kāi)發(fā)中的應用
在用C語(yǔ)言編程時(shí),如何實(shí)現這一功能呢?C語(yǔ)言中有指向函數的指針這一概念,可以利用這種指針來(lái)實(shí)現用函數指針調用函數。指向函數的指針變量的定義格式為:
類(lèi)型標識符 (*指針變量名)();
在定義好指針后就可以給指針變量賦值,使其指向某個(gè)函數的開(kāi)始存地址,然后用
(*指針變量名)()即可調用這個(gè)函數。如下例:
void main(void)
{
void (*DispBuffer)(); /*定義指向函數指針*/
DispBuffer=0xde00; /*賦值*/
for(;;)
{ Key();
DispBuffer();
}
}
三、將浮點(diǎn)數轉化為字符數組
筆者在編制應用程序時(shí)有這樣的要求:將運算的結果(浮點(diǎn)數)存入EEPROM中。我們知道,浮點(diǎn)數在C語(yǔ)言中是以IEEE格式存儲的,一個(gè)浮點(diǎn)數占用四個(gè)字節,例如浮點(diǎn)數34.526存為(160,26,10,66)這四個(gè)數。要將一個(gè)浮點(diǎn)數存入EEPROM,實(shí)際上就是要存這四個(gè)數。那么如何在程序中得到一個(gè)浮點(diǎn)數的組成數呢?
浮點(diǎn)數在存儲時(shí),是存儲連續的字節中的,只要設法找到存儲位置,就可以得到這些數了??梢远x一個(gè)void的指針,將此指針指向需要存儲的浮點(diǎn)數,然后將此指針強制轉化為char型,這樣,利用指針就可以得到組成該浮點(diǎn)數的各個(gè)字節的值了。具體程序如下:
#define uchar unsigned char#define uint unsigned intvoid FtoC(void)
{ float a;
uchar i,*px
uchar x[4]; /*定義字符數組,準備存儲浮點(diǎn)數的四個(gè)字節*、
void *pf;
px=x; /*px指針指向數組x*/
pf=a; /*void 型指針指向浮點(diǎn)數首地址*/
a=34.526;
for(i=0;i4;i++)
{ *(px+i)=*((char *)pf+i); /*強制void 型指針轉成char型,因為*/
} /*void型指針不能運算*/
}
如果已將數存入EEPROM,要將其取出合并,方法也是一樣,可參考下面的程序。
#define uchar unsigned char#define uint unsigned int
void CtoF(void)
{ float a;
uchar i,*px
uchar x[4]={56,180,150,73};
void *pf;
px=x;
pf=a;
for(i=0;i4;i++)
{ *((char *)pf+i)=*(px+i);
}
}
以上所用C語(yǔ)言為FRANKLIN C51 VER 3.2。本文引用地址:http://dyxdggzs.com/article/172750.htm
評論