當前位置:首頁 » 編程語言 » 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;
}

熱點內容
伺服器的空島如何刷錢 發布:2024-11-15 09:40:52 瀏覽:262
安卓系統錄像設置在哪裡 發布:2024-11-15 09:36:33 瀏覽:917
電信級伺服器電腦 發布:2024-11-15 09:26:27 瀏覽:246
壓縮某個文件夾 發布:2024-11-15 09:03:11 瀏覽:891
網址能解壓嗎 發布:2024-11-15 08:54:09 瀏覽:933
python更改目錄 發布:2024-11-15 08:41:08 瀏覽:265
伺服器快閃記憶體可以裝在一般電腦上嗎 發布:2024-11-15 08:36:46 瀏覽:8
安卓手機怎麼查詢自己的路線軌跡 發布:2024-11-15 08:32:19 瀏覽:969
phpdatet 發布:2024-11-15 08:32:17 瀏覽:507
HDB3編解碼實驗 發布:2024-11-15 08:17:31 瀏覽:212