函数参数的压栈方式

函数参数的压栈方式:从右至左这个大家都知道可是怎么应用呢??微笑先来看一个企鹅的面试题。

#include<stdio.h>

void main()
{
	long long a = 1;
	long long b = 2;
	long long c = 3;
 	printf("%d%d%d",a,b,c);
}
(小端模式)输出为1,0,2由与从左至右压栈

一个框表示一个字节。先取下面四个字节为1,往上取4个字节为0,最后去4个字节为2。所以输出为1,0,2。这个可能不是很明显我们再看一个。微笑

#include <stdio.h>


void main()
{
	int a[] = {6,7,8,9,10};
	int *ptr = a;
	*(ptr++) += 123;
	printf("%d%d",*(ptr),*(++ptr));


}

这个输出为8,8而不是大家所谓的7,8。因为*(++ptr)先入所以ptr指向8,再将*ptr入栈所以为8,这样再出栈是就为8,8。这样就是结果8,8。 微笑


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值