电话
400 9058 355
printf类型不匹配会导致未定义行为,如%u对应size_t应为%zu,传nullptr给%s会段错误;C++无运行时检查,全靠开发者保证格式符与参数类型、顺序一致。
比如 %d 对应 int,传入 long long 就是未定义行为(常见 crash 或乱码)。C++ 不做运行时类型检查,printf 完全依赖你手写的格式符和实参顺序一致。
常见踩坑点:
printf("%d", my_size_t_value); —— size_t 在 64 位系统通常是 unsigned long,用 %d 错,该用 %zu
printf("%s", nullptr); —— 直接段错误,cout 则安全输出 0 或空字符串(取决于标准库实现)
printf("%.3f", x) 可控,但无法统一设置全局精度,每次都要写cout 本身不带格式参数,靠插入操作符 和 std::setprecision、std::hex 等操纵器组合。所有类型由重载决定,编译期检查,不会因类型错导致崩溃。
典型用法:
cout 输出 ff;之后需手动恢复:cout
cout 输出 3.142
cout 输出 00000042
注意:std::setw 只对下一个输出项生效,std::setprecision 和 std::fixed 是持久的,直到被覆盖。
printf 默认行缓冲(遇到 \n 刷出),cout 默认也是行缓冲,但二者缓冲区独立。混用时如:
printf("start ");
cout << "mid
dle" << endl;
printf("end\n");
输出可能是 start end 换行后才出 middle,尤其在重定向到文件或管道时更明显。
解决办法(二选一):
std::ios::sync_with_stdio(false); 关闭同步(提升性能,但禁止混用)printf 后加 fflush(stdout),或 cout 后加 cout.flush()
std::format 是类型安全、格式清晰、无缓冲冲突的方案,语法类似 Python 的 str.format():
#include#include std::string s = std::format("value={:.2f}, count={:04d}", 3.14159, 42); std::cout << s << "\n"; // value=3.14, count=0042
它比 printf 安全,比 cout 简洁,且支持编译期检查(部分实现已支持)。不过目前 MSVC 支持较好,GCC/Clang 需要较新版本(≥13)并开启 -std=c++20。
如果项目不能用 C++20,fmt 库({fmt})是成熟替代,API 几乎一致,只需把 std::format 换成 fmt::format。
真正难处理的是遗留代码里那些靠 printf 的动态格式字符串(比如日志模板),或者需要极致性能的嵌入式场景——这时还得盯紧格式符和类型的对应关系,别光看编译过没过。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...