C語言中有模板函數(shù)嗎? 模板不是c++中才提供的特性的嘛,大部分函數(shù)都是自定義函數(shù)。沒有什么優(yōu)點(diǎn)或者缺點(diǎn)吧,完全看函數(shù)自身的功能
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:主機(jī)域名、虛擬空間、營銷軟件、網(wǎng)站建設(shè)、江華網(wǎng)站維護(hù)、網(wǎng)站推廣。
c語言中用戶自定義函數(shù)的格式:
函數(shù)返回類型? 函數(shù)名(參數(shù)列表)
{
代碼段;
return 函數(shù)返回值;
}
例如:
int?test(int?value)
{
value?+=?10;
return?value;
}
上面示例定義了一個名為test的函數(shù),其返回值為int型,參數(shù)為int型,返回值為參數(shù)與10之和。
注:函數(shù)類型為void時,不可有return語句。
#include "stdio.h"
#include "string.h"
void Func(void)
{
printf("\r\n自定義函數(shù)起動!!!\r\n");
}
int main()
{
printf("Hello world!\n");
while(1)
{
Func();
}
return 0;
}
首先,C沒有函數(shù)模版。C++才有。
其次,template class T是函數(shù)聲明的一部分,所以下面函數(shù)實現(xiàn)應(yīng)該是:
template class T
void swap(T a,T b){
int temp;
temp=a;
a=b;
b=temp;
}
最后,#include iostream,在標(biāo)準(zhǔn)的C++函數(shù)中,std的域中已經(jīng)有一個swap函數(shù)。
而且前面也using namespace了。函數(shù)聲明重復(fù)。
兩個辦法:
1 swap(i,j);改為 ::swap(i,j); //全局化。
2 swap改個名字。
如果要寫個函數(shù)支持多種數(shù)據(jù)類型,首先想到的就是C++的模板了,但是有時候只能用C語言,比如在linux內(nèi)核開發(fā)中,為了減少代碼量,或者是某面試官的要求…
考慮了一陣子后,就想到了qsort上.qsort的函數(shù)原型:
void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );
快排時,只要自己實現(xiàn)相應(yīng)數(shù)據(jù)類型的比較函數(shù)cmpare就可以了.如果比較int型時,一個典型的compare函數(shù)如下:
那么,就是說可以利用void *. void *意指未指定類型,也可以理解為任意類型。其他類型的指針可以直接賦值給void *變量,但是void *變量需要強(qiáng)制類型轉(zhuǎn)換為其它指針類型。這個相信大家都知道。那么下面以一個簡單的題目為例,來探討如何在C語言中實現(xiàn)模板函數(shù)。
方法1: 利用void *.
在看下面的源程序之前,需要了解幾點(diǎn)。首先,在32位平臺上,任何類型的指針?biāo)嫉淖止?jié)都是4個字節(jié),因為32位機(jī)器虛擬內(nèi)存一般為4G,即2的32次方,只要32位即4個字節(jié)就可以足夠?qū)ぶ?,sizeof(void *)=4; 其次,雖然各種不同類型的指針?biāo)嫉目臻g都為4個字節(jié),但是不同類型的指針?biāo)傅目臻g的字節(jié)數(shù)卻不同(這一點(diǎn)尤為重要,下面的程序我在開始沒有調(diào)通就因為這點(diǎn)意識不強(qiáng))。所以,如果你將一個指針強(qiáng)制轉(zhuǎn)換為另一個類型的指針,指針本身所占的字節(jié)是不變的,但是,如果對這個指針進(jìn)行運(yùn)算,比如 *p,p++,p-=1等一般都是不同的。 再次,函數(shù)指針應(yīng)該了解下,這里不多說。 最后,因為Sandy跟我說,C++開始的時候模板的實現(xiàn)其實就是利用宏替換,在編譯的時候確定類型。所以,為了方便,類型也用了預(yù)編譯指令#define。
span#include?"stdio.h"/span
span#include?"stdlib.h"/span
span//typedef?int?T;??//或者下面的也可以./span
span#define??T?int/span
//這個FindMin是Sandy寫的.felix021也寫了個,差不多的就不貼出來的.
void?FindMin(const?void??*arr,int?arr_size,int?arrmembersize,int?*index,
int?(*cmp)(const?void?*,const?void?*b)){
int?i;
*index=0;
char?*p=(char?*)arr;
char?*tmp=p;
for?(i=1;iarr_size?;i++){
if?(cmp(tmp,p)0){
tmp=p;
}
p+=arrmembersize;
}
(*index)=((int)(tmp-arr))/arrmembersize;
}
*//span
可以把指針看作是char?*,如果轉(zhuǎn)換為int?*,那下面的位移就不正確了./span
indexspan=/spanispan;/span
span}/span
span}/span
spanreturn/span?indexspan;/span
span}/span
spanint/span?resultspan;/spanspan//result保存的是最小值索引./span
resultspan=/spanFindMinspan(/spanarr,span12/span,
來個樣例程序(輸入兩個數(shù),求最大公約數(shù))
#include stdio.h
#include stdlib.h
int a,b;
int gcd(int x,int y)
{
if (x%y==0)
return y;
else
return gcd(y,x%y);
}
int main()
{
scanf("%d%d",a,b);
printf("%d\n",gcd(a,b));
return 0;
}