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;
}
相关推荐
xrgs_shz4 分钟前
MATLAB的数据类型和各类数据类型转化示例
开发语言·数据结构·matlab
厂太_STAB_丝针1 小时前
【自学嵌入式(8)天气时钟:天气模块开发、主函数编写】
c语言·单片机·嵌入式硬件
charlie1145141913 小时前
从0开始使用面对对象C语言搭建一个基于OLED的图形显示框架(协议层封装)
c语言·驱动开发·单片机·学习·教程·oled
来恩10033 小时前
C# 类与对象详解
开发语言·c#
*TQK*3 小时前
ZZNUOJ(C/C++)基础练习1041——1050(详解版)
c语言·c++·编程知识点
komo莫莫da4 小时前
寒假刷题Day19
java·开发语言
ElseWhereR4 小时前
C++ 写一个简单的加减法计算器
开发语言·c++·算法
*TQK*4 小时前
ZZNUOJ(C/C++)基础练习1031——1040(详解版)
c语言·c++·编程知识点
※DX3906※5 小时前
cpp实战项目—string类的模拟实现
开发语言·c++
wjs20245 小时前
Nginx 安装配置指南
开发语言