这是我的问题。我有 Gcc 4.4.1,但该功能不存在,我安装了 4.3 和 4.5 版本,结果相同 :-/
我知道这个函数不是 C-ANSI 标准,但我没有编写代码,我需要在我的发行版中编译它。我的一个朋友在 Fedora 中有相同版本的编译器,并且 Gcc 编译没有问题(使用 stdio.h 和 stdlib.h)。
因此,如果有人能告诉我该函数在我的编译器中是否可用,我将不胜感激。
问候。
顺便说一句:这是我的 gcc 版本:
:~$ gcc -v
Using built-in specs.
Target: i686-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.4.4-14ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.4/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.4 --enable-shared --enable-multiarch --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.4 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-objc-gc --enable-targets=all --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=i686-linux-gnu --host=i686-linux-gnu --target=i686-linux-gnu
Thread model: posix
gcc version 4.4.5 (Ubuntu/Linaro 4.4.4-14ubuntu5
答案1
它似乎没有在 4.4.4 中定义,但如果你不关心 10 以外的基数
char *itoa(long i, char* s, int dummy_radix) {
sprintf(s, "%ld", i);
return s;
}
是一种快速且粗糙(且经过测试)的替代方案。
答案2
void itoa(int n, char s[])
{
int i, sign;
if ((sign = n) < 0) /* записываем знак */
n = -n; /* делаем n положительным числом */
i = 0;
do { /* генерируем цифры в обратном порядке */
s[i++] = n % 10 + '0'; /* берем следующую цифру */
} while ((n /= 10) > 0); /* удаляем */
if (sign < 0)
s[i++] = '-';
s[i] = '\0';
reverse(s);
}
如果你需要反向功能:
#include <string.h>
/* reverse: переворачиваем строку s на месте */
void reverse(char s[])
{
int i, j;
char c;
for (i = 0, j = strlen(s)-1; i<j; i++, j--) {
c = s[i];
s[i] = s[j];
s[j] = c;
}
}
我从俄罗斯维基百科获得了这个实现。