C语言中关于printf()输出的时候的一个出栈入栈问题

先看一段代码,可以自己尝试一下,反正我当时尝试的时候好多搞不懂,

不过现在搞懂了,里面牵扯到了一个入栈和出栈的问题,


官方解释是这个:


c 复制代码
因为C语言函数参数入栈顺序是从右到左的,所以计算顺序是从右到左开始计算的;对于a++的结果,
是有ebp寻址函数栈空间来记录中间结果的,在最后给printf压栈的时候,再从栈中把中间结果取出来;
而对于++a的结果,则直接压寄存器变量,寄存器经过了所有的自增操作。

大白话解释:

c 复制代码
挑选一个举个例子:
printf("%s,%d\n\n", (zp++)->name, (++zp)->age);

从右开始往左扫描,先扫描到(++zp)->age,
对于"++zp"那么计算机会先进行zp的自增操作,然后把zp放到一个寄存器变量中
(直白点就是暂时放到一边,暂时不进行zp->age的指向,等整个printf扫描一遍扫描完了然后再进行zp->age指向)
但是之后的扫描过程中zp的值是寄存器变量中的那个值,也就是zp=zp+1的值,

然后扫描到了(zp++)->name,
对于"zp++",计算机会先进行把zp->name 所指向的值存在栈空间中,然后再进行zp = zp+1  操作
(直白点就是说zp->name这个值已经定了,不管你printf扫描完还是没扫描完zp怎么变都跟我zp->name没关系了)
c 复制代码
#include <stdio.h>
struct Person{
	char name[20];
	int age;
};
int main()
{
    struct Person *zp, p[3] = {
		{"wang",12},
		{"liu",13},
		{"zhang",14}
	};
	zp = p;
	
	printf("%s,%d\n\n", (zp++)->name, zp->age);  //wang 13

	zp = p;//初始化
	printf("%s,%d\n\n", zp->name, (zp++)->age);  //liu 12

	zp = p;//初始化
	printf("%s,%d\n\n", (zp++)->name, zp->age);   //wang 13

	zp = p;//初始化
	printf("%s,%d\n\n", zp->name, (zp++)->age);   //liu 12

	zp = p;//初始化
	printf("%s,%d\n\n", (zp++)->name, (++zp)->age);   //liu 14

   return 0;
}
相关推荐
史迪奇_xxx5 分钟前
10、一个简易 vector:C++ 模板与 STL
java·开发语言·c++
2301_801252229 分钟前
Java中的反射
java·开发语言
Kiri霧30 分钟前
Rust开发环境搭建
开发语言·后端·rust
weixin-a1530030831634 分钟前
[数据抓取-1]beautifulsoup
开发语言·python·beautifulsoup
小杨同学yx1 小时前
有关maven的一些知识点
java·开发语言
我是华为OD~HR~栗栗呀1 小时前
华为od-21届考研-C++面经
java·c语言·c++·python·华为od·华为·面试
oioihoii2 小时前
C++ 中的类型转换:深入理解 static_cast 与 C风格转换的本质区别
java·c语言·c++
重生之我要当java大帝2 小时前
java微服务-尚医通-编写医院设置接口下
java·开发语言·sql
寻找华年的锦瑟2 小时前
Qt-QDir
开发语言·qt
小妖6662 小时前
vscode 怎么运行 c++ 文件
开发语言·c++