gpt4 book ai didi

c - 为什么这个函数返回null?

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

此代码查找字符串中的下一个单词。

例如

输入 "my cake" 函数应该返回 "my cake"。作为预期的输出

如果我使用 return 则输出为 (null),但我使用 printf 则代码有效

我想知道如何使用 return 获得预期的输出。

       #include <stdio.h>
int main()
{
char* str[1000];
printf("enter:");
fgets(str,1000,stdin);

printf("%s",find_word_start(str));
}



char* find_word_start(char* str){
char* result[1000];
int c = 0, d = 0;
while(str[c] ==' ') {
c++;
}
while(str[c] != '\0'){
result[d++] = str[c++];

if(str[c]==' ') {
result[d++] = str[c++];
}
while(str[c]==' ') { //
c++;
}
}
result[d] = '\0';

//print or return char?
return result;
}

最佳答案

char* result[1000]; 创建一个包含 1000 个指针的数组。这在很多方面都是错误的。

  1. 您需要一个包含 1000 个字符的 block ,而不是指针。
  2. 实际上,1000 不是您想要的字符数。您通常需要较小的数字,但也可能需要较大的数字。
  3. 您不想将结果存储在自动分配的内存中,因为一旦您退出该函数,它就会被释放。使用 malloc(或执行 malloc 的东西,例如 strdup)。

修复:

// Returns a copy that needs to be freed.
char* find_word_start(const char* src) {
while (*src == ' ')
++src;

size_t len = 0;
while (str[len] != '\0')
++len;

++len; // Include NUL
result = malloc(len);

char* dst = result;
while (len--)
*(dst++) = *(src++);

return result;
}

好吧,我避免像你那样使用上面的字符串函数,但它们极大地简化了解决方案。

// Returns a copy that needs to be freed.
char* find_word_start(const char* src) {
while (*src == ' ')
++src;

return strdup(src);
}

也就是说,由于您返回了字符串的尾端,您可以简单地返回指向现有字符串的指针。

// Returns a pointer into the provided string.
const char* find_word_start(const char* str) {
while (*str == ' ')
++str;

return str;
}

关于c - 为什么这个函数返回null?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57940452/

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