C++中应避免使用非标准的itoa和不安全的sprintf,优先选用std::to_string(C++11)或std::format(C++20);前者简洁安全但仅支持十进制,后者功能强大且类型安全,支持进制、对齐等格式化。
直接说结论:C++ 中没有标准的 itoa,它不是 ISO C++ 函数;sprintf 可用但不安全;推荐用 std::to_string(C++11 起)或 std::format(C++20 起)。
itoa
itoa 是某些 C 库(如 MSVC、glibc 扩展)提供的非标准函数,ISO C++ 标准完全不包含它。跨平台编译时大概率报错:error: 'itoa' was not declared in this scope。即使在 Windows 下能用,参数顺序(目标缓冲区在前还是数字在前)、返回值含义也不统一。
itoa(int value, char* buffer, int base)
char*

-D_GNU_SOURCE 且仍不保证可用sprintf 怎么用、有什么风险sprintf 是标准 C 函数,C++ 可用,头文件为 。它把格式化结果写入字符数组,但不检查目标缓冲区大小,极易导致栈溢出或内存越界。
常见错误写法:
char buf[4]; sprintf(buf, "%d", 1234); // 缓冲区太小,写入 "1234\0" 需要 5 字节 → 越界
安全做法(仍不推荐):
int 最多 11 位(含符号),申请 char buf[12]
snprintf(C99+,C++11 可用):snprintf(buf, sizeof(buf), "%d", n),会截断并确保末尾 \0
snprintf 返回值是「欲写入长度」,不是是否成功,需判断是否 >= sizeof(buf) 来确认截断std::to_string
最简洁、类型安全、无需管理内存:
int n = -42; std::string s = std::to_string(n); // s == "-42" const char* c_str = s.c_str(); // 如需 C 风格字符串,注意生命周期
限制与注意点:
std::string,若需 char 数组,必须复制(如 strcpy(dest, s.c_str())),且确保 dest 足够大std::format
功能对标 printf,但类型安全、无缓冲区风险,支持进制、宽度、填充:
#includeint n = 255; std::string s1 = std::format("{}", n); // "255" std::string s2 = std::format("{:x}", n); // "ff" std::string s3 = std::format("{:04d}", n); // "0255" std::string s4 = std::format("{:>8}", n); // " 255"
当前兼容性注意:
-std=c++20 并确认标准库实现(libstdc++/libc++/MSVC STL)是否完成 std::format
真正容易被忽略的是:所有转换都涉及「生命周期管理」——std::to_string 返回的 std::string 对象一旦析构,其内部 c_str() 就失效;而 sprintf 写入的缓冲区若在栈上分配,离开作用域即不可用。别只盯着“怎么转”,得想清楚“转完存在哪、谁负责释放、用多久”。