c++程式設計師經常需要處理c語言下程式
這裡,先展示一下,c++中用c語言的方法寫乙個帶有變長引數的函式,and呼叫。
#includeusing std::cout;
using std::endl;
#include
//等等用到的巨集定義va_list等等在這個c的標頭檔案中
//帶有變長引數的函式,實現n個double資料的求和功能
double add(int n, ... )
return total;}//
call function add(int ,...)
int main(void)
c語言神奇而博大精深,我必須檢視一下vc中對va_等等巨集的定義
typedef char * va_list;
#define _intsizeof(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
#define va_start(ap,v) ( ap = (va_list)&v + _intsizeof(v) )
#define va_arg(ap,t) ( *(t *)((ap += _intsizeof(t)) - _intsizeof(t)) )
#define va_end(ap) ( ap = (va_list)0 )
巨集很強大!我來分析一下
typedef char * va_list; //ap是乙個字串,因為這裡需要對位的操作
#define _intsizeof(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
//例如乙個int整型,n = 8(位) //(15) 00001111 // //11111000 //
//00001000,實現了記憶體對齊
#define va_start(ap,v) ( ap = (va_list)&v + _intsizeof(v) )
#define va_arg(ap,t) ( *(t *)((ap += _intsizeof(t)) - _intsizeof(t)) )//
#define va_end(ap) ( ap = (va_list)0 )
可以參考此處的更深入的分析。
C C 函式變長引數列表實現
在c編譯器通常提供了一系列處理可變引數的巨集,實現就像printf 那樣的變長引數列表,這樣可以遮蔽不同的硬體平台造成的差異,增加程式的可移植性。這些巨集包括va start va arg和va end等,這些巨集都是在標頭檔案裡定義的。採用ansi標準形式時,引數個數可變的函式的原型宣告是 typ...
python變長引數列表 可變長引數
可變長引數 預設情況下,必須使用正確數量的引數呼叫函式,這意味著,如果您的函式需要2個引數,則必須使用2個引數 不多也不少 來呼叫函式。示例,該函式需要2個引數,並獲得2個引數 def my function fname,lname print fname lname my function emi...
變長引數列表函式
可變引數列表 標頭檔案提供了遍歷未知數目和型別的函式引數表的功能。該標頭檔案的實現因不同的機器而不同,但提供的介面是一致的。假定函式 f 帶有可變數目的實際引數,lastarg 是它的最後乙個命名的形式引數 引數列表必須至少包括乙個命名引數 那麼,在函式 f 內宣告乙個型別為 va list 的變數...