C語(yǔ)言中編寫(xiě)可變參數(shù)函數(shù)
通過(guò)stdarg.h頭文件為函數(shù)提供了定義可變參數(shù)列表的能力。聲明一個(gè)可變參數(shù)的函數(shù)類似:
void f1(int n,...);
其中n表示參數(shù)列表個(gè)數(shù),而用省略號(hào)來(lái)表示未知參數(shù)列表。stdarg.h中提供了一個(gè)va_list類型,用于存放參數(shù)。一個(gè)大概的使用過(guò)程類似:
void f1(int n,...) { va_list ap; va_start(ap,n); //初始化參數(shù)列表 double first=va_arg(ap,double); //取第一個(gè)參數(shù) int second=va_arg(ap,int); //取第二個(gè)參數(shù) ... va_end(ap); //清理工作 }
看一個(gè)求和的例子:
#include < stdio.h > #include < stdarg.h > double sum( int , ); int main( void ) { double s,t; s = sum( 3 , 1.1 , 2.2 , 13.3 ); t = sum( 6 , 1.1 , 2.1 , 13.1 , 4.1 , 5.1 , 6.1 ); printf( " return value for " \ " sum(3,1.1,2.2,13.3): %g\n " ,s); printf( " return value for " \ " sum(6,1.1,2.1,13.1,4.1,5.1,6.1): %g\n " ,t); return 0 ; } double sum( int lim, ) { va_list ap; double total = 0 ; va_start(ap,lim); int i; for (i = 0 ;i < lim;i ++ ) total += va_arg(ap, double ); va_end(ap); return total; }
C語(yǔ)言對(duì)可變參數(shù)的使用還是有點(diǎn)麻煩,不如ruby和java簡(jiǎn)便。比如ruby中定義并使用可變參數(shù)參數(shù):
def sum(*e) e.inject{|sum,i| sum+=i} end sum(1,2,3,4,5)=>15
相關(guān)文章
C++?解決求兩個(gè)鏈表的第一個(gè)公共結(jié)點(diǎn)問(wèn)題
本文主要介紹了利用C++實(shí)現(xiàn)輸入兩個(gè)無(wú)環(huán)的單向鏈表時(shí),找出它們的第一個(gè)公共結(jié)點(diǎn)的問(wèn)題。文章中的示例代碼簡(jiǎn)潔易懂,感興趣的同學(xué)可以和小編一起學(xué)習(xí)一下2021-12-12C++ 中CloseHandle 函數(shù)--關(guān)閉一個(gè)句柄
這篇文章主要介紹了C++ 中CloseHandle 函數(shù)--關(guān)閉一個(gè)句柄的相關(guān)資料,需要的朋友可以參考下2017-05-05C++利用棧實(shí)現(xiàn)中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式
這篇文章主要為大家詳細(xì)介紹了C++利用棧實(shí)現(xiàn)中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04基于C++11的threadpool線程池(簡(jiǎn)潔且可以帶任意多的參數(shù))
C++11 加入了線程庫(kù),從此告別了標(biāo)準(zhǔn)庫(kù)不支持并發(fā)的歷史。然而 c++ 對(duì)于多線程的支持還是比較低級(jí),稍微高級(jí)一點(diǎn)的用法都需要自己去實(shí)現(xiàn),譬如線程池、信號(hào)量等2019-04-04c++ chrono 獲取當(dāng)前時(shí)間的實(shí)現(xiàn)代碼
這篇文章主要介紹了c++ chrono 獲取當(dāng)前時(shí)間的實(shí)現(xiàn)代碼,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07C++求四個(gè)正整數(shù)最大公約數(shù)的方法
這篇文章主要介紹了C++求四個(gè)正整數(shù)最大公約數(shù)的方法,涉及C++求余算法的運(yùn)用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-05-05QT升級(jí)6.0以上版本遇到問(wèn)題以及解決方法
更新新的QT后以前的舊版本建立的工程,自然會(huì)出現(xiàn)兼容性的問(wèn)題,本文主要介紹了QT升級(jí)6.0以上版本遇到問(wèn)題以及解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03