在C

时间:2016-08-18 04:14:41

标签: c string idioms string-building

这似乎是一个之前会被问过的问题,但我无法找到它。 (如果你这样做,请指出我并将其作为副本关闭。)

我有C代码,其工作原理如下:

printf("some characters");
for (; n >= 0; n--)
{
    printf(", %s", f(n, k));
}
printf("more characters");

对于某些变量nk以及函数char* f(int n, int k)这些并不重要。 (nk不是常量。)我想将上面的代码转换为返回char*的函数,而不是简单地使用printf来显示它。 (它最终将被打印,但这可以让我做一些重构,当然更容易测试。)当然我可以创建字符串并逐个字符地复制它们但肯定有更好的(更干净,更快,更惯用的方式。

在我的特定应用程序中f是一个非常简单的函数,类似于itos的相对,但由于k而无法以任何有意义的方式缓存。但我欢迎那些对这种情况有益的想法,因为它可能对将来的其他人有用。

1 个答案:

答案 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的大小。