这似乎是一个之前会被问过的问题,但我无法找到它。 (如果你这样做,请指出我并将其作为副本关闭。)
我有C代码,其工作原理如下:
printf("some characters");
for (; n >= 0; n--)
{
printf(", %s", f(n, k));
}
printf("more characters");
对于某些变量n
和k
以及函数char* f(int n, int k)
这些并不重要。 (n
和k
不是常量。)我想将上面的代码转换为返回char*
的函数,而不是简单地使用printf
来显示它。 (它最终将被打印,但这可以让我做一些重构,当然更容易测试。)当然我可以创建字符串并逐个字符地复制它们但肯定有更好的(更干净,更快,更惯用的方式。
在我的特定应用程序中f
是一个非常简单的函数,类似于itos
的相对,但由于k
而无法以任何有意义的方式缓存。但我欢迎那些对这种情况有益的想法,因为它可能对将来的其他人有用。
答案 0 :(得分:5)
步骤1将为字符串分配足够大的缓冲区。然后使用sprintf
打印到缓冲区。标准习语是
int index = sprintf( buffer, "some characters" );
for (; n >= 0; n--)
{
index += sprintf( &buffer[index], ", %s", f(n, k) );
}
index += sprintf( &buffer[index], "more characters" );
sprintf
函数返回它写入的字符串的长度,这使您可以跟踪缓冲区中的位置。
您也可以让调用者传递缓冲区和大小。在这种情况下,最好使用snprintf
来避免超出缓冲区。所以函数看起来像这样
char *create_string( char *buffer, int size, int n, int k )
{
...
index += snprintf( &buffer[index], size-index, ", %s", f(n, k) );
...
return buffer;
}
其中size
参数是buffer
的大小。