C語言函數(shù)可以使用如下語法來編寫:
公司主營業(yè)務(wù):成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出威遠免費做網(wǎng)站回饋大家。
```cint function_name(int param1, int param2){ // 函數(shù)的定義 // 變量聲明和定義 // 具體的操作 // 返回值 return result;}```
拓展:C語言函數(shù)的編寫實質(zhì)上是編寫一個獨立的程序模塊,可以指定不同的參數(shù),以及函數(shù)返回值。C語言函數(shù)也可以定義不同的函數(shù)原型,以及變量作用域,以實現(xiàn)更復(fù)雜的功能。
這個程序的目的是打印出2-100內(nèi)所有的素數(shù)。 首先2是一個很特殊的素數(shù),偶素數(shù)就那么一個,呵呵! 接下來for(i=3;i=100;i+=2)的目的就是遍歷所有可能的奇數(shù)。 而for(k==2;ksqrt(i)tag==0;k++)一段就是判斷i是否為素數(shù)。 這里的tag是一個作為標(biāo)簽,0代表是素數(shù),1代表的是合數(shù)。 注意到 if(i%k==0) tag=1; 表示有數(shù)字可整除它的時候,那么它就不是素數(shù)了。 if(tag==0) printf("%d, ",i); 前面已經(jīng)提到了,0代表是素數(shù),那么就打印咯~~
各種用 C 語言實現(xiàn)的模板可能在使用形式上有所不同?,F(xiàn)以一個求和函數(shù) Sum 為例,用 C++ Template 可寫如下:
template R Sum(const T *array, int n)
{
R sum = 0;
for (int i = 0 ; i n ; ++i)
sum += i;
return sum;
}
如果不是內(nèi)置類型,該模板隱式地需要 有R R::operator+=(T)運算符可用。
1. 使用函數(shù)指針作為 Functor 替換者
Typedef struct tagAddClass
{
Void (*add)(char* r1, const char* r2);
Int elemSize;
Char sum[MAX_ELEM_SIZE];
} AddClass;
void Sum(AddClass* self, const char* array, int n)
{
for (int i = 0 ; i n ; ++i)
self-add(self-sum, array + i*self-elemSize);
}
使用時:
Void AddInt(char* r1, const char* r2) {
*(long*)r1 += *(int*)r2; }
AddClass addClass = {AddInt, 2, 0 };
Int array[100];
Read(array);
Sum(addClass, array, 100); …..
2. 用宏作為Functor的替換者
#define GenSumFun(SumFunName, Add, RetType, ElemType)
RetType SumFunName (const ElemType *array, int n) \
{
RetType sum = 0;
for (int i = 0 ; i n ; ++i)
Add(sum, i);
return sum; }
使用時:
#define AddInt(x, y) ((x) += (y))
GenSumFun(SumInt, AddInt, long, int) …..
Int array[100];
Read(array);
Long sum = SumInt(array, 100); …..
3. 所有可替換參數(shù)均為宏
至少需要一個額外的文件(實現(xiàn)文件)為 impsum.c
/* impsum.c */
RetType FunName(const ElemType *array, int n)
{
RetType sum = 0;
for (int i = 0 ; i n ; ++i)
Add(sum, i);
return sum; }
使用時:
#undef RetType
#undef FunName
#undef ElemType
#undef Add
#define AddInt(x, y) ((x) += (y))
#define RetType long
#define FunName SumInt
#define ElemType int
#define Add AddInt
#include impsum.c …..
Int array[100];
Read(array);
Long sum = SumInt(array, 100);
4. 總結(jié):
第一種方法,易于跟蹤調(diào)試,但是效率低下,適用于對可變函數(shù)(函數(shù)指針)的效率要求不高,但程序出錯的可能性較大(復(fù)雜),模板函數(shù)(Sum)本身很復(fù)雜,模板參數(shù)也比較復(fù)雜(add)的場合。
第二種方法,效率高,但很難跟蹤調(diào)試,在模板函數(shù)和模板參數(shù)本身都很復(fù)雜的時候更是如此。
第三種方法,是我最近幾天才想出的,我認為是最好的,在模板參數(shù)(Add)比較復(fù)雜時可以用函數(shù)(第二種也可以如此),簡單時可以用宏,并且,易于調(diào)試。在模板函數(shù)本身很復(fù)雜,而模板參數(shù)比較簡單時更為優(yōu)越。但是,可能有點繁瑣。
tag的含義其實就是一個flag,標(biāo)記遇到空格時的處理
因為遇到空格的時候有可能是一個單詞開始或者是一個單詞的終止
當(dāng)tag==1的時候判斷是單詞終止
此時sum++
當(dāng)tag==0的時候是單詞開始 此時不計數(shù) 再遇到空格是sum++