1. 程式人生 > >C語言中: va_list 解決變參問題

C語言中: va_list 解決變參問題

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; }