= 0;-6ren">
gpt4 book ai didi

c - 在 C 中构建字符串

转载 作者:太空宇宙 更新时间:2023-11-04 01:01:12 24 4
gpt4 key购买 nike

这似乎是一个以前会被问到的问题,但我找不到它。 (如果你这样做,请指点我并关闭它作为副本。)

我有这样的 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 步是为字符串分配足够大的缓冲区。然后使用 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 的大小。

关于c - 在 C 中构建字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39009894/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com