以往寫(xiě)C語(yǔ)言程序都是一個(gè)文件里面寫(xiě)個(gè)幾十、幾百行,在練算法的時(shí)候還可以,現(xiàn)在搞開(kāi)發(fā)需要模塊化編程,所謂模塊化編程,就是指一個(gè)程序包含多個(gè)源文件(.c 文件和 .h 文件),每個(gè) .c 文件可以被稱(chēng)為一個(gè)模塊。
1、例程的文件結(jié)構(gòu)
2、各文件代碼main.c 源碼:
#include
{
intn1 = 1, n2 = 10;
printf("從%d加到%d的和為%ld\n", n1, n2, sum(n1, n2));
printf("從%d乘到%d的積為%ld\n", n1, n2, mult(n1, n2));
printf("OS:%s\n",OS);
printf("Power By %s(%s)", getWebName(), getWebURL());
return0;
}
math.c 源碼:
// 沒(méi)有使用到 func.h 中的函數(shù)聲明或宏定義,也可以不包含進(jìn)來(lái)
#include "../include/func.h"
// 從 fromNum 加到 endNumlongsum(intfromNum, intendNum)
{
inti;
longresult = 0;
// 參數(shù)不符合規(guī)則,返回 -1
if(fromNum<0?|| endNum<0?|| endNum
{
return-1;
}
for(i=fromNum; i<=endNum; i++)
{
result += i;
}
// 返回大于等于0的值
returnresult;
}
// 從 fromNum 乘到 endNumlongmult(intfromNum, intendNum)
{
inti;
longresult = 1;
// 參數(shù)不符合規(guī)則,返回 -1
if(fromNum<0?|| endNum<0?|| endNum
{
return-1;
}
for(i=fromNum; i<=endNum; i++)
{
result *= i;
}
// 返回大于等于0的值
returnresult;
}
web.c 源碼:
// 使用到了 func.h 中的宏定義,必須包含進(jìn)來(lái),否則編譯錯(cuò)誤
#include "../include/func.h"char* getWebName()
{
returnWEB_NAME;
}char* getWebURL()
{
returnWEB_URL;
}
func.h 源碼:
#ifndef _FUNC_H
#define _FUNC_H
// 用宏定義來(lái)代替全局變量
#define OS "Linux"
#define WEB_URL "http://www.baidu.com"
#define WEB_NAME "百度"
// 也可以省略 extern,不過(guò)為了程序可讀性,建議都寫(xiě)上
externlongsum(int, int);
externlongmult(int, int);
externchar* getWebName();
externchar* getWebURL();
#endif
運(yùn)行結(jié)果:
從1加到10的和為55從1乘到10的積為3628800OS:Linux
-
C語(yǔ)言
+關(guān)注
關(guān)注
180文章
7605瀏覽量
136934 -
源文件
+關(guān)注
關(guān)注
0文章
30瀏覽量
4596
原文標(biāo)題:通俗易懂!Linux C模塊化編程實(shí)例講解
文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論