函数参数的压栈顺序

(Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu 转载请标明来源)


先来看一道面试题:

设int arr[]={1,2,3,4 };

int *ptr=arr;

printf("%d,%d",*ptr,*(++ptr));

面试题的答案是: 2, 2

 

这个面试题为什么会这样呢? 原因就跟函数的压栈顺序有关,先压栈哪一个,哪一个就会被先计算,后压栈哪一个,那一个就会被后计算。

 

对于常见的C++程序,像缺省_cdecl或使用_stdcall的函数压栈顺序都是采用的从右往左压栈的。(_pascall使用的从左往右压栈。)

 

我个人认为从右往左压栈的好处比较明显,把第一个参数放在了栈顶,取用比较方便,另外对于可变参数而言,使用第一个参数可以确定剩余哪些输入参数需要取用。

 

下面也是一个例子,用于进一步说明从右往左取的参数:

void TestFunc()

{

         int arr[] = {6, 7, 8, 9};

         int nSize = sizeof(arr)/sizeof(int);

         ViewArray(arr, nSize);

        

         int* ptr = arr;

         *(ptr++) += 1;

         ViewArray(arr, nSize);

 

         printf("result: %d, %d", *ptr, *(++ptr)); 

         printf("result: %d, %d", *(++ptr), *ptr);

}

 

像上面的输出为

6 7 8 9

7 7 8 9

8, 8

9, 8

 

(Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu 转载请标明来源)


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春夜喜雨

稀罕你的喜欢!!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值