C語言中: va_list 解決變參問題
阿新 • • 發佈:2019-01-29
VA_LIST 是在C語言中解決變參問題的一組巨集,所在標頭檔案:#include <stdarg.h>
,用於獲取不確定個數的引數
——摘自百度百科
va_list 是一個字元指標,在程式碼中可以理解為指向當前引數的一個指標,這裡有幾個與 va_list 相關的常見的函式
void va_start ( va_list ap, param );
//對va_list變數進行初始化,將ap指標指向引數列表中的第一個引數
type va_arg ( va_list ap, type );
//獲取引數,型別為 type 型別,返回值也為 type 型別
int vsprintf(char *string, char *format, va_list ap);
//將ap(通常是字串) 按format格式寫入字串string中
void va_end ( va_list ap );
//回收ap指標
所以解決變參問題就分為四步:
(1)首先在函式裡定義 va_list 型的變數 ap,即指向引數的指標;
(2)然後用 va_start 函式初始化剛定義的 ap 指標;
(3)然後用 va_arg 返回可變的引數即 va_arg(va_list ap, type)
(4)最後用 va_list 回收 va_list 指標
eg.:求多個數的最大值:
code:
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
int Max(int ss, ...){
va_list ap;
int ret = -999999, tmp;
va_start(ap, ss);
for(int i=0; i<ss; i++){
tmp = va_arg(ap, int);
if(ret < tmp)
ret = tmp;
}
va_end(ap);
return ret;
}
int main()
{
int cnt = 5;
printf("%d\n",Max(cnt, 2, 3, 4, 5, 6));
return 0;
}