设为首页 加入收藏

TOP

printf的实现原理
2014-10-31 08:00:08 来源: 作者: 【 】 浏览:54
Tags:printf 实现 原理

  在C/C++中,对函数参数的扫描是从后向前的。C/C++的函数参数是通过压入堆栈的方式来给函数传参数的(堆栈是一种先进后出的数据结构),最先压入的参数最后出来,在计算机的内存中,数据有2块,一块是堆,一块是栈(函数参数及局部变量在这里),而栈是从内存的高地址向低地址生长的,控制生长的就是堆栈指针了,最先压入的参数是在最上面,就是说在所有参数的最后面,最后压入的参数在最下面,结构上看起来是第一个,所以最后压入的参数总能被函数找到,因为它就在堆栈指针的上方,printf第一个被找到的参数就是那个字符指针,就是双引号括起来的那一部分,函数通过判断字符串里控制参数的个数来判断参数个数及数据类型,通过这些就可算出个数据需要的堆栈指针的偏移量了,下面给出printf("%d,%d",a,b);(其中a,b都是int型的)汇编代码


  .section .data string out=“%d,%d”


  push b;


  push a;


  push $out


  call printf


  看到没参数是最后的先压如,最先的后压入,参数控制的那个字符串常量最后压入,所以这个常量总是能被找到。


  编辑特别推荐:


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇C宏定义探析 下一篇如何解决系统补丁(KB971092)重..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: