|
|
|
|
| C语言参数个数可变如printf()函数原型中的问题 |
 C语言参数个数可变如printf()函数原型中的问题 - rshy11 [ 2005-10-25 19:18 | 1,203 byte(s)]
 Re: C语言参数个数可变如printf()函数原型中的问题 - antzcn [ 2005-10-25 20:09 | 443 byte(s)]
 Re: C语言参数个数可变如printf()函数原型中的问题 - rshy11 [ 2005-10-26 11:25 | 476 byte(s)]
 Re: C语言参数个数可变如printf()函数原型中的问题 - antzcn [ 2005-10-26 13:16 | 103 byte(s)]
|
|
|
|
[Original]
[Print]
[Top]
|
在stdarg.h中可以看到:
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 )
#define _INTSIZEOF(n) ((sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
定义_INTSIZEOF(n)主要是为了某些需要内存的对齐的系统.这个宏的目的是为了得到最后一个固定参数的实际内存大小。
那位大虾能解释一下上面这行:
有&又有~,究竟是怎样实现的,为什么这个宏就能表示最后一个固定参数的内存大小??另外sizeof(n),其中n是char *型,那sizeof(n)指的就是地址的字节数吧,有什么用?
#define va_arg(ap,t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) )
这个宏做了两个事情,
①用用户输入的类型名对参数地址进行强制类型转换,得到用户所需要的值
②计算出本参数的实际大小,将指针调到本参数的结尾,也就是下一个参数的首地址,以便后续处理。
这行的第②点也不清楚,???
thx
|
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
((sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
即
(1 + ((sizeof(n) - 1) / sizeof(int))) * sizeof(int)
即
参数类型的大小是整形大小的整数倍(后者比前者耗时)!
#define va_arg(ap, t) ( *(t *)((ap += _INTSIZEOF(t)) - _INTSIZEOF(t)) )
即
取出当前参数: *(t *)ap
并把指针指向下一个参数: ap += _INTSIZEOF(t)
多看看书!
|
|
|
----
Freedom!
|
|
[Original]
[Print]
[Top]
|
|
[Original]
[Print]
[Top]
|
((sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
即
(1 + ((sizeof(n) - 1) / sizeof(int))) * sizeof(int)
即
参数类型的大小是整形大小的整数倍(后者比前者耗时)!
提到的(1 + ((sizeof(n) - 1) / sizeof(int))) * sizeof(int) 不就是
((sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) ) 的前面部分:((sizeof(n) + sizeof(int) - 1)吗?
后面的& ~(sizeof(int) - 1)去那了??
|
|
|
[Original]
[Print]
[Top]
|
|
|