代码:
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 )
理解:
1:
#define _INTSIZEOF(n) ( (sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
目的是把sizeof(n)的结果变成至少是sizeof(int)的整倍数,一般用来在结构中实现按int的倍数对齐。
2:
#define va_start(ap,v) ( ap = (va_list)&v + _INTSIZEOF(v) )
将ap指针指向参数v的下一参数地址处。
3:
#define va_arg(ap,t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) )
这条代码目的是将指针移动到下一参数后,再返回上一地址将上一地址的值取出。原理:根据运算顺序会先执行(ap += _INTSIZEOF(t))相当于ap=ap+_INTSIZEOF(t),也就是将指针ap指向下一地址;然后再执行- _INTSIZEOF(t)回到原地址,并转化为类型*的指针,再取指针所指地址的值。
4:
#define va_end(ap) ( ap = (va_list)0 )
结束指针ap的使用,避免出现野指针。