当前位置: 首页 > news >正文

printf函数参数与入栈顺序

01. printf()的核心功能

作用:将 格式化数据 输出到 标准输出(stdout),支持多种数据类型和格式控制。

在这里插入图片描述

int printf(const char *format, ...);
  • 参数
    • format:格式字符串,字符串或%开头格式符
    • ...:可变参数,与" "内格式一一对应
  • 返回值:成功返回输出的字符数,失败返回负数

eg:

int count = printf("Hello, %s!\n", "World");
printf("输出了 %d 个字符\n", count); // 输出:输出了 13 个字符

02. printf()格式说明符

常用格式符

格式符数据类型示例
%dintprintf(“%d”, 66);
%uunsigned intprintf(“%u”, 66);
%ffloat/doubleprintf(“%.2f”, 6.666);
%ccharprintf(“%c”, ‘A’);
%s字符串printf(“%s”, “hello world”);
%p指针地址printf(“%p”, &x);
%zusize_tprintf(“%zu”, 100);
%x十六进制整数printf(“%x”, 66);

格式控制

默认右对齐,使用-可左对齐输出。%m.ns表示向右对齐占m列,左边不足补空格,输出字符只占n位,超出n位删去。同理%m.nf亦是如此。

  • 填充与对齐

    printf("%5d", 10);    //  "   10"。从右开始输出,不足处补空格
    printf("%-5d", 10);   //  "10   "。从左开始输出,不足处补空格
    printf("%05d", 7);    //  "00007"。从右开始输出,不足处补0
    
  • 精度控制

    printf("%.3f", 3.14159); //  "3.142"。保留3位小数
    printf("%.6s", "hello world"); // 输出前6个字符 "hello "
    

03. printf() 的参数入栈顺序

C标准未规定参数求值顺序。大多数编译(GCC、Clang)默认从右往左入栈顺序,这样可以支持…可变参数。这里讨论常见情况。

注意: 不同编译器可能出现不同的结果。

示例代码

int i = 1;
printf("%d, %d, %d\n", i++, i++, i++);
//GCC 一般情况输出  3, 2, 1

验证入栈顺序:

在这里插入图片描述
Linux下:
在这里插入图片描述

&a > &b > &c 符合栈的生长方向。

  • 参数入栈顺序:从右到左(c→b→a→格式串),但 64位系统优先用寄存器(前6个参数通过 rdi, rsi, rdx, rcx, r8, r9 传递)。
  • 参数访问顺序printf 按格式字符串的 % 顺序 从左到右 从寄存器或栈中读取参数。

参数传递:

  • rdi = 格式字符串地址
  • rsi = a 的值 (10)
  • rdx = b 的值 (20)
  • rcx = c 的值 (30)

输出顺序
printf%p 顺序读取 rsi→rdx→rcx,因此输出 &a, &b, &c

在这里插入图片描述

03. printf()输出流程

程序 内存缓冲区 标准输出(stdout) printf 屏幕 调用printf("Value: %d", 42)无`\0` 格式化字符串并写入缓冲区 满足条件时刷新(如缓冲区满、遇到\n) 显示"Value: 42" 程序 内存缓冲区 标准输出(stdout) printf 屏幕

04. 缓冲区机制

  • 行缓冲:默认模式(终端输出),遇到 \n 或缓冲区满时刷新。
  • 全缓冲:文件输出,缓冲区满或调用 fflush 时刷新。
  • 无缓冲:如 stderr,立即输出。

2. 强制刷新示例

printf("Processing...");  // 无换行符,行缓冲下不会立即显示
fflush(stdout);           // 强制刷新到屏幕

http://www.xdnf.cn/news/514693.html

相关文章:

  • 翻到了一段2005年写的关于需求的文字
  • java每日精进 5.18【文件存储】
  • Ubuntu 18.04设置静态IP的方法(图形化操作)
  • 美丽的独处时光
  • 菱形继承原理
  • java集合相关的api-总结
  • 2025年- H27-Lc135- 239.滑动窗口最大值(自定义双端队列)---java版
  • 量子计算在金融科技中的应用前景
  • [Codeforce刷题8]
  • 无废话离线大模型安装
  • 【随机过程】贝叶斯估计
  • 游戏引擎学习第292天:实现蛇
  • es聚合-词条统计
  • 量子计算 | 量子密码学的挑战和机遇
  • LWIP的NETCONN接口
  • APP手机端测试覆盖点
  • 专业漏洞扫描机构如何助力企业保障安全并提升竞争力?
  • 【MySQL】库与表的操作
  • 力扣热题——数组的最小相等和
  • 关于 Web 漏洞原理与利用:1. SQL 注入(SQLi)
  • 基于FPGA的电子万年历系统开发,包含各模块testbench
  • ​Docker 网络
  • 前端三剑客之HTML
  • 深入解析Python中的Vector2d类:从基础实现到特殊方法的应用
  • nginx服务器实验
  • 23种设计模式解释+记忆
  • 虚幻引擎5-Unreal Engine笔记之`GameMode`、`关卡(Level)` 和 `关卡蓝图(Level Blueprint)`的关系
  • 快速上手SElinux
  • 第8章 常用实用类
  • 基于shardingsphere的分库分表方案