當前位置:首頁 » 編程語言 » c語言模板

c語言模板

發布時間: 2022-01-24 00:00:43

c語言程序模板

#include<stdio.h>
int main()
{
double c,f;
scanf("%lf",&f);
c=5.0/9*(f-32);
printf("攝氏溫度:");
printf("%.2lf\n",c);
return 0;
}

② c語言編程時的模板裡面{跟//是什麼意思

{和}是匹配的
表示一個單獨的程序段。
當if while for等 這類控制語句,要包含多餘一句的語句時 需要用{}括起來。

//表示注釋 。 //之後到行末 只給編寫程序的人看, 編譯器不會處理。

③ c語言中一個模板中「^!」是什麼意思

是你所想像的那麼復雜:
你所定義的min函數模板和xutility的min函數模板的名字是一樣的,編譯器認為你是在重載xutility中的min函數,而你那樣重載明顯是不行的!所以的話你只要改一下函數的名字即可。
#include <iostream>,這一行將iostream包含進來了,估計這個文件或者是它所包含的文件中一某一個頭文件將xutility文件include進來了。。。
然後你又using namespace std;使用std命名空間,而xutility中的min函數模板正是定義在std名字空間之下,所以xutility中的min函數模板起作用了。
你將using namespace std;去掉也可以解決問題, 但cout換成std::cout,endl換成std::endl即可。
至於VC6對STL的支持有限,固並沒有所錯。
希望我的問答對你有所幫助!

④ 用c-free寫windows的函數有像c語言那樣的模板嗎



把代碼放在模板。到時候右鍵就可以選擇插入了

⑤ C語言模板函數與自定義函數的區別及優缺點

C語言中有模板函數嗎? 模板不是c++中才提供的特性的嘛,大部分函數都是自定義函數。沒有什麼優點或者缺點吧,完全看函數自身的功能

⑥ 有用c語言編寫程序的模板嗎

開打易語言 在新建窗口中選擇 WINDOWS易語言模塊寫完後編譯出來的就是 .EC格式的易模塊文件

⑦ c語言的模板偏特化是什麼意思

假設你明白特化:偏特化就是特化的一種。就是特化參數類型較多的時候,只特化一部分,另外一部分不做特化。
http://blog.csdn.net/shinehoo/article/details/5723618

⑧ 在c語言中如何實現函數模板

如果要寫個函數支持多種數據類型,首先想到的就是C++的模板了,但是有時候只能用C語言,比如在linux內核開發中,為了減少代碼量,或者是某面試官的要求…
考慮了一陣子後,就想到了qsort上.qsort的函數原型:
void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );
快排時,只要自己實現相應數據類型的比較函數cmpare就可以了.如果比較int型時,一個典型的compare函數如下:

那麼,就是說可以利用void *. void *意指未指定類型,也可以理解為任意類型。其他類型的指針可以直接賦值給void *變數,但是void *變數需要強制類型轉換為其它指針類型。這個相信大家都知道。那麼下面以一個簡單的題目為例,來探討如何在C語言中實現模板函數。
方法1: 利用void *.
在看下面的源程序之前,需要了解幾點。首先,在32位平台上,任何類型的指針所佔的位元組都是4個位元組,因為32位機器虛擬內存一般為4G,即2的32次方,只要32位即4個位元組就可以足夠定址,sizeof(void *)=4; 其次,雖然各種不同類型的指針所佔的空間都為4個位元組,但是不同類型的指針所指的空間的位元組數卻不同(這一點尤為重要,下面的程序我在開始沒有調通就因為這點意識不強)。所以,如果你將一個指針強制轉換為另一個類型的指針,指針本身所佔的位元組是不變的,但是,如果對這個指針進行運算,比如 *p,p++,p-=1等一般都是不同的。 再次,函數指針應該了解下,這里不多說。 最後,因為Sandy跟我說,C++開始的時候模板的實現其實就是利用宏替換,在編譯的時候確定類型。所以,為了方便,類型也用了預編譯指令#define。

<span>#include"stdio.h"</span>

<span>#include"stdlib.h"</span>

<span>//typedefintT;//或者下面的也可以.</span>

<span>#defineTint</span>

//這個FindMin是Sandy寫的.felix021也寫了個,差不多的就不貼出來的.

voidFindMin(constvoid*arr,intarr_size,intarrmembersize,int*index,

int(*cmp)(constvoid*,constvoid*b)){

inti;

*index=0;

char*p=(char*)arr;

char*tmp=p;

for(i=1;i<arr_size;i++){

if(cmp(tmp,p)>0){

tmp=p;

}

p+=arrmembersize;

}

(*index)=((int)(tmp-arr))/arrmembersize;

}

*/</span>

可以把指針看作是char*,如果轉換為int*,那下面的位移就不正確了.</span>

index<span>=</span>i<span>;</span>

<span>}</span>

<span>}</span>

<span>return</span>index<span>;</span>

<span>}</span>

<span>int</span>result<span>;</span><span>//result保存的是最小值索引.</span>

result<span>=</span>FindMin<span>(</span>arr,<span>12</span>,

⑨ 有沒有大神提供一個c語言源代碼的模板 能夠點一下就能切換一個界面

#include <stdlib.h> #include <windows.h> #include "stdio.h" void main() { int n; printf("歡迎界面");//歡迎界面 Sleep(1000);//延時 system("cls");//清屏 //菜單界面 printf("***********************************************\n"); printf("*************1、 ***********************\n"); printf("*************2、 ***********************\n"); printf("*************3、 ***********************\n"); printf("***********************************************\n"); //菜單選擇 scanf("%d",&n); if(n==1){} else if(n==2){} else if(n==3){} else {printf("錯誤!");} } 希望能幫助你,喜歡請採納,有問題歡迎追問!

⑩ c語言,函數,函數模板

for (i=0; i<n; i++)
{
proizv[i]=pro(a[i],n); //用函數調用代替注釋掉的循環
// proizv[i]=1;
// for(j=0; j<n; j++)
// {
// if(a[i][j]>0) proizv[i]*=a[i][j];
// else proizv[i]=0;
// }
if(proizv[i]>0) printf("Proizvedenie elementov stroki %d ravno %d\n",i+1,proizv[i]);
}

system("PAUSE");
}
int pro(int *v,int n) //函數定義
{
int s=1;
while(n--)
{
if(*v>0) s*=*v;
else s=0;
v++;
}
return s;
}
------------------
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
//int pro(int *v,int n); //<-改成下面的
template<class T> T pro(T *v,int n);
int main()
{
...
...
...
for (i=0; i<n; i++)
{
proizv[i]=pro(a[i],n); //用函數調用代替注釋掉的循環
// proizv[i]=1;
// for(j=0; j<n; j++)
// {
// if(a[i][j]>0) proizv[i]*=a[i][j];
// else proizv[i]=0;
// }
if(proizv[i]>0) printf("Proizvedenie elementov stroki %d ravno %d\n",i+1,proizv[i]);
}

system("PAUSE");
}
template<class T> T pro(T *v,int n)
{
T s=1;
while(n--)
{
if(*v>0) s*=*v;
else s=0;
v++;
}
return s;
}

熱點內容
samp伺服器如何設置ip直播 發布:2025-01-08 12:35:20 瀏覽:120
5七的演算法 發布:2025-01-08 12:30:59 瀏覽:444
linuxsvn配置 發布:2025-01-08 12:19:11 瀏覽:380
蘋果扁頭耳機如何在安卓手機上用 發布:2025-01-08 12:17:37 瀏覽:109
為什麼解綁卡還要密碼 發布:2025-01-08 12:13:51 瀏覽:73
反編譯得到源代碼的比例 發布:2025-01-08 12:12:36 瀏覽:619
蘋果手機7z怎麼解壓 發布:2025-01-08 12:11:55 瀏覽:121
租用的雲伺服器還需要流量么 發布:2025-01-08 12:11:30 瀏覽:584
為什麼手游對手機配置要求低 發布:2025-01-08 12:06:53 瀏覽:214
怎麼設置qq郵箱獨立密碼 發布:2025-01-08 11:58:14 瀏覽:387