i=i 1; i ; i–;
這三個語句都通常引用在for()或者是while()里邊,從執(zhí)行效率上來說 3》2》1
這和最終生成的匯編語言有關,一般來說,影響不會太夸張。
switch-case語句
switch-case語句,也是用的非常多的語句。
這里首先的優(yōu)化原則就是:將發(fā)生概率最高的條件,放在最先判斷的位置。這樣就能夠有效的降低比較的次數(shù),達到更優(yōu)的效果。或者,有一種更好的方法來替代switch-case語句的方法,就是利用查表
比如
switch(msg_type) { case DATA: handle_data_fun(); break; case RTS: handle_rts_fun(); break; ……. }
這里就可以用函數(shù)指針和查表的方式,獲得handle_fun的方法來替代。
處理函數(shù)都在初始化的過程中,放到*handle_fun[MAX]相應的位置上
int (*handle_fun[MAX])(struct msg_t *msg); int msg_type = msg->type; handle_fun[msg_type](msg);//即可
這種方法,在Linux的網(wǎng)絡協(xié)議里邊,用的非常多,一般對應的查表方式為hash表結構。
sturct 和 union的使用
sturcut 使用,一定要考慮到字節(jié)對其的問題,struct中,不同的安排順序,sizeof是不同的所以要調(diào)整好位置,盡量保證struct的size最小。
union的使用,比如對不同包的數(shù)據(jù)結構上,是不一樣的,所以盡量使用union來區(qū)分不同的包結構這樣對程序的可讀性比較好。
volatile的使用
這在驅(qū)動編程方面是非常有用的一個標志。目的是不讓編譯器compiler把當前的變量優(yōu)化掉。尤其是涉及到硬件寄存器的值的時候。
乘除運算的簡化
乘除運算,對arm來說太致命,arm的乘除都生成一堆的匯編指令才能完成。所以一般可以通過位操作,比如移位,取低位來進行適當?shù)幕?。比?a*8 = a<<3;
Inline 函數(shù)
在實現(xiàn)比較簡單功能的函數(shù),以及那些調(diào)用非常平凡的函數(shù),都可以在函數(shù)前加入inline的標識。這樣在產(chǎn)生匯編的時候,能夠更有效。也可以替代較復雜的define語句。
更多關于云服務器,域名注冊,虛擬主機的問題,請訪問西部數(shù)碼官網(wǎng):m.ps-sw.cn