va_arg实现

前几天测试的时候,遇到了个问题,顺便看了下printf的实现。

讲下废话,测试是为了什么呢?几个月前测试6500指令集的我改了下代码,
目的是为了能让测试通过,好在周末休息下,可是测试就是为了让程序在硬件上
跑通吗?测试,本身就是为了发现问题,而我在进行指令集的时候却试图改变代码,
以试图在芯片未流片前就用软件修正自身的问题,可是我们在这个阶段是完全可以
可以更该一些错误的啊。测试的时候,发现问题很好啊,不然还要测试干嘛……
废话讲多了,进入正题:printf实现部分的va_start, va_arg, va_end。

C参数中在栈中的存储方式为从右到左,栈的生长方向为从高到低,无论是大端还是小端,
低地址都是作为变量的地址。

 

      1 typedef char * va_list;
      2
      3 #define __INTSIZEOF(n) \
      4     ((sizeof(n) + sizeof(int) - 1) & ~(sizeof(int) - 1) )
      5
      6 #define __ADDRESS(v) (&(v))
      7
      8 #define va_start(ap, v) \
      9     (ap = (va_list) __ADDRESS(v) + __INTSIZEOF(v))
     10
     11 #define va_arg(ap, t) \
     12     (*(t*)((ap += __INTSIZEOF(t)) - __INTSIZEOF(t)))
     13
     14 #define va_end(ap) \
     15     (ap = (va_list) 0)  

posted on 2012-12-24 15:42  阿加  阅读(681)  评论(0编辑  收藏  举报

导航