std::format 是 C++20 引入的类型安全、高性能字符串格式化工具,需编译器支持(Clang/GCC 13+、MSVC 19.30+),并显式启用标准(-std=c++20 或 /std:c++20)及正确链接运行时库。
std::format 在 C++20 中是标准库引入的类型安全、高性能字符串格式化工具,但它**不是所有编译器默认启用的**——你得确认编译器支持、标准版本、且链接了必要运行时(尤其是 MSVC)。
Clang 和 GCC 13+、MSVC 19.30+(VS 2025 17.0+)才提供完整实现。但即

-std=c++20 或更高(-std=c++23 也行),-lstdc++ 默认包含,无需额外链接/std:c++20,且必须链接 libcmt.lib 或 msvcrt.lib;若报 undefined symbol: "class std::basic_string __cdecl std::format..." ,说明链接缺失或未启用 /Zc:__cplusplus
std::format 的 locale 支持不全,慎用 {:L} 等本地化格式符std::format 接收一个格式字符串和若干参数,返回 std::string(或 std::wstring 对应 std::wformat)。格式语法类似 Python 的 f-string,但更严格。
std::string s = std::format("Hello, {}! You have {} new messages.", "Alice", 42);
// → "Hello, Alice! You have 42 new messages."
常用格式说明符:
{}:自动类型推导,调用 std::formatter 特化(内置类型都已特化){:d}:十进制整数(int 默认就是 d,可省略){:x}:小写十六进制;{:X} 大写{:.2f}:浮点数保留两位小数(f 强制定点表示){:>10}:右对齐、最小宽度 10;{: 左对齐;{:^6} 居中
{:+d}:强制显示正号(+123 而非 123)最常遇到的不是语法错,而是编译器/标准库不匹配导致的链接错误或 SFINAE 失败:
std::format 处理 const char* 非字面量:格式字符串必须是字面量(constexpr 字符串),否则编译失败 —— std::format(fmt_str, ...) 中 fmt_str 不能是运行时变量std::format_error 异常:比如对 std::string 用 {:x},或对 double 用 {:d}
std::wformat 实现较晚(GCC 14 才稳定),MSVC 更早支持;混用 std::format 和 std::wformat 参数会导致类型推导失败std::formatter,且必须在使用前声明;漏掉 parse() 或 format() 成员将导致编译错误,错误信息冗长难读如果你的目标环境无法保证 C++20 完整支持(如嵌入式、旧版 CI),不要硬上 std::format:
absl::StrFormat(Abseil)或 fmt::format({fmt} 库)——它们 API 高度兼容 std::format,且编译期检查更友好std::ostringstream 仍可靠,只是无格式字符串语法糖std::to_chars 性能最高(无内存分配、无异常),但需自己处理缓冲区真正麻烦的从来不是怎么写 std::format("{}", x),而是确保构建链每个环节都认得它 —— 编译器、标准库、CMake 配置、CI 镜像版本,缺一不可。