引言
要說的話
模塊即是一個.c 文件和一個.h 文件的結合,頭文件(.h)中是對于該模塊接口的聲明;
#include …
…
//定義變量
unsigned char value;//全局變量
…
//定義函數(shù)
//這是本模塊第一個函數(shù),起到延時作用,只供本模塊的函數(shù)調用,所以用到static關鍵字修飾
/********************延時子程序************************/
static void delay (uint us) //delay time
{}
//這是本模塊的第二個函數(shù),要在其他模塊中調用
/*********************寫字符程序**************************
** 功能:向LCD寫入字符
** 參數(shù):dat_comm 為1寫入的是數(shù)據(jù),為0寫入的是指令
content 為寫入的數(shù)字或指令
******************************************************/
void wr_lcd (uchar dat_comm,uchar content)
{}
……
……
/***************************** END Files***********************************/
//聲明全局變量
extern unsigned char value;
//聲明接口函數(shù)
extern void wr_lcd (uchar dat_comm,uchar content); //向LCD寫入字符
……
/***************************** END Files***********************************/
-
在keil 編譯器中,extern這個關鍵字即使不聲明,編譯器也不會報錯,且程序運行良好,但不保證使用其它編譯器也如此。強烈建議加上,養(yǎng)成良好的編程規(guī)范。
-
.c文件中的函數(shù)只有其它模塊使用時才會出現(xiàn)在.h文件中,像本地延時函數(shù)static void delay (uint us)即使出現(xiàn)在.h文件中也是在做無用功,因為其它模塊根本不去調用它,實際上也調用不了它(static關鍵字的限制作用)。
-
注意本句最后一定要加分號”;”,相信有不少同學遇到過這個奇怪的編譯器報錯: error C132: 'xxxx': not in formal parameter list,這個錯誤其實是.h的函數(shù)聲明的最后少了分號的緣故。
#include“l(fā)cd_device.h //包含液晶驅動程序頭文件,之后就可以在該.c文件中調用//lcd_device.h中的全局函數(shù),使用液晶驅動程序里的全局//變量(如果有的話)。
…
//調用向LCD寫入字符函數(shù)
wr_lcd (0x01,0x30);
…
//對全局變量賦值
value=0xff;
…
某模塊提供給其它模塊調用的外部函數(shù)及數(shù)據(jù)需在.h 中文件中冠以extern 關鍵字聲明;
比如上例的變量value就是一個全局變量,若是某個模塊也使用這個變量,則和使用外部函數(shù)一樣,只需在使用的模塊.c文件中包含#include“l(fā)cd_device.h”即可。
#ifdef xxx_GLOBALS
#define xxx_EXT
#else
#define xxx_EXT extern
#endif
#define xxx_GLOBALS
#include "includes.h"
#ifdef OS_GLOBALS
#define OS_EXT
#else
#define OS_EXT extern
#endif
OS_EXT INT32U OSIdleCtr;
OS_EXT INT32U OSIdleCtrRun;
OS_EXT INT32U OSIdleCtrMax;
#define OS_GLOBALS
#include “includes.h”
INT32U OSIdleCtr;
INT32U OSIdleCtrRun;
INT32U OSIdleCtrMax;
extern INT32U OSIdleCtr;
extern INT32U OSIdleCtrRun;
extern INT32U OSIdleCtrMax;
模塊內的函數(shù)和全局變量需在.c 文件開頭冠以static 關鍵字聲明;
比如上例在LCD驅動模塊.c文件中定義的延時函數(shù)static void delay (uint us),這個函數(shù)冠以static修飾,一方面是限定了函數(shù)的作用范圍只是在本模塊中起作用,另一方面也給人傳達這樣的信息:該函數(shù)不會被其他模塊調用。
-
在函數(shù)體,一個被聲明為靜態(tài)的變量在這一函數(shù)被調用過程中維持其值不變。
-
在模塊內(但在函數(shù)體外),一個被聲明為靜態(tài)的變量可以被模塊內所用函數(shù)訪問,但不能被模塊外其它函數(shù)訪問。它是一個本地的全局變量。
-
在模塊內,一個被聲明為靜態(tài)的函數(shù)只可被這一模塊內的其它函數(shù)調用。那就是,這個函數(shù)被限制在聲明它的模塊的本地范圍內使用。
永遠不要在.h 文件中定義變量!
/*module1.h*/
int a = 5; /* 在模塊1 的.h 文件中定義int a */
/*module1 .c*/
#include "module1.h" /* 在模塊1 中包含模塊1 的.h 文件 */
/*module2 .c*/
#include "module1.h" /* 在模塊2 中包含模塊1 的.h 文件 */
/*module3 .c*/
#include "module1.h" /* 在模塊3 中包含模塊1 的.h 文件 */
/*module1.h*/
extern int a; /* 在模塊1 的.h 文件中聲明int a */
/*module1 .c*/
#include "module1.h" /* 在模塊1 中包含模塊1 的.h 文件 */
int a = 5; /* 在模塊1 的.c 文件中定義int a */
/*module2 .c*/
#include "module1.h" /* 在模塊2 中包含模塊1 的.h 文件 */
/*module3 .c*/
#include "module1.h" /* 在模塊3 中包含模塊1 的.h 文件 */
-
硬件驅動模塊,一種特定硬件對應一個模塊;
-
軟件功能模塊,其模塊的劃分應滿足低偶合、高內聚的要求。
往期好文合集
厲害了!華為繼鴻蒙OS后,即將發(fā)布國產(chǎn)編程語言,打破國外壟斷!
2020年9月編程語言排行榜:C語言繼續(xù)第一,你站哪個?
太贊了:中文版開源!這或許是最經(jīng)典的計算機編程教材
??最 后
??
?
免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!