新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 寫出高效優(yōu)美的單片機(jī)C語(yǔ)言代碼

寫出高效優(yōu)美的單片機(jī)C語(yǔ)言代碼

作者: 時(shí)間:2013-07-01 來源:網(wǎng)絡(luò) 收藏

兩個(gè)函數(shù)的延時(shí)效果相似,但幾乎所有的C編譯對(duì)后一種函數(shù)生成的均比前一種少1~3個(gè)字節(jié),因?yàn)閹缀跛械腗CU均有為0轉(zhuǎn)移的指令,采用后一種方式能夠生成這類指令。在使用while循環(huán)時(shí)也一樣,使用自減指令控制循環(huán)會(huì)比使用自加指令控制循環(huán)生成的更少1~3個(gè)字母。但是在循環(huán)中有通過循環(huán)變量“i”讀寫數(shù)組的指令時(shí),使用預(yù)減循環(huán)時(shí)有可能使數(shù)組超界,要引起注意。

(3)while循環(huán)和do…while循環(huán)

用while循環(huán)時(shí)有以下兩種循環(huán)形式:

unsigned int i;

i=0;

while (i1000)

{

i++;

//用戶程序

}

或:

unsigned int i;

i=1000;

do

i--;

//用戶程序

while (i>0);

在這兩種循環(huán)中,使用do…while循環(huán)編譯后生成的代碼的長(zhǎng)度短于while循環(huán)。

7、查表

在程序中一般不進(jìn)行非常復(fù)雜的運(yùn)算,如浮點(diǎn)數(shù)的乘除及開方等,以及一些復(fù)雜的數(shù)學(xué)模型的插補(bǔ)運(yùn)算,對(duì)這些即消耗時(shí)間又消費(fèi)資源的運(yùn)算,應(yīng)盡量使用查表的方式,并且將數(shù)據(jù)表置于程序存儲(chǔ)區(qū)。如果直接生成所需的表比較困難,也盡量在啟了,減少了程序執(zhí)行過程中重復(fù)計(jì)算的工作量。

比如使用在線匯編及將字符串和一些常量保存在程序存儲(chǔ)器中,均有利于優(yōu)化

宏定義技巧(常用宏定義)

寫好,漂亮的宏定義很重要,使用宏定義可以防止出錯(cuò),提可移植性,可讀性,方便性 等等。下面列舉一些成熟軟件中常用得宏定義。。。。。。

相關(guān)鏈接:新手入門系列中的優(yōu)秀編程風(fēng)格說明:http://www.avrvi.com/start/guide_avr_c_good.html

CODE:

1,防止一個(gè)頭文件被重復(fù)包含

#ifndef COMDEF_H

#define COMDEF_H

//頭文件內(nèi)容

#endif

2,重新定義一些類型,防止由于各種平臺(tái)和編譯器的不同,而產(chǎn)生的類型字節(jié)數(shù)差異,方便移植。

typedef unsigned char boolean; /* Boolean value type. */

typedef unsigned long int uint32; /* Unsigned 32 bit value */

typedef unsigned short uint16; /* Unsigned 16 bit value */

typedef unsigned char uint8; /* Unsigned 8 bit value */

typedef signed long int int32; /* Signed 32 bit value */

typedef signed short int16; /* Signed 16 bit value */

typedef signed char int8; /* Signed 8 bit value */

//下面的不建議使用

typedef unsigned char byte; /* Unsigned 8 bit value type. */

typedef unsigned short word; /* Unsinged 16 bit value type. */

typedef unsigned long dword; /* Unsigned 32 bit value type. */

typedef unsigned char uint1; /* Unsigned 8 bit value type. */

typedef unsigned short uint2; /* Unsigned 16 bit value type. */

typedef unsigned long uint4; /* Unsigned 32 bit value type. */

typedef signed char int1; /* Signed 8 bit value type. */

typedef signed short int2; /* Signed 16 bit value type. */

typedef long int int4; /* Signed 32 bit value type. */

typedef signed long sint31; /* Signed 32 bit value */

typedef signed short sint15; /* Signed 16 bit value */

typedef signed char sint7; /* Signed 8 bit value */

3,得到指定地址上的一個(gè)字節(jié)或字

#define MEM_B( x ) ( *( (byte *) (x) ) )

#define MEM_W( x ) ( *( (word *) (x) ) )

4,求最大值和最小值

#define MAX( x, y ) ( ((x) > (y)) ? (x) : (y) )

#define MIN( x, y ) ( ((x) (y)) ? (x) : (y) )

5,得到一個(gè)field在結(jié)構(gòu)體(struct)中的偏移量

#define FPOS( type, field )

/*lint -e545 */ ( (dword) (( type *) 0)-> field ) /*lint +e545 */

6,得到一個(gè)結(jié)構(gòu)體中field所占用的字節(jié)數(shù)

#define FSIZ( type, field ) sizeof( ((type *) 0)->field )

7,按照LSB格式把兩個(gè)字節(jié)轉(zhuǎn)化為一個(gè)Word

#define FLIPW( ray ) ( (((word) (ray)[0]) * 256) + (ray)[1] )

8,按照LSB格式把一個(gè)Word轉(zhuǎn)化為兩個(gè)字節(jié)

#define FLOPW( ray, val )

(ray)[0] = ((val) / 256);

(ray)[1] = ((val) 0xFF)

9,得到一個(gè)變量的地址(word寬度)

#define B_PTR( var ) ( (byte *) (void *) (var) )

#define W_PTR( var ) ( (word *) (void *) (var) )

10,得到一個(gè)字的位和低位字節(jié)

#define WORD_LO(xxx) ((byte) ((word)(xxx) 255))

#define WORD_HI(xxx) ((byte) ((word)(xxx) >> 8))

11,返回一個(gè)比X大的最接近的8的倍數(shù)

#define RND8( x ) ((((x) + 7) / 8 ) * 8 )

12,將一個(gè)字母轉(zhuǎn)換為大寫

#define UPCASE( c ) ( ((c) >= 'a' (c) = 'z') ? ((c) - 0x20) : (c) )

13,判斷字符是不是10進(jìn)值的數(shù)字

#define DECCHK( c ) ((c) >= '0' (c) = '9')

c語(yǔ)言相關(guān)文章:c語(yǔ)言教程




關(guān)鍵詞: 單片機(jī) C語(yǔ)言 代碼

評(píng)論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉