c - 动态和静态字符数组

标签 c arrays string

程序代码如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char * cloning(char * q){
    char s[strlen(q)];
    int i;
    for(i = 0; i < strlen(q); i++)
        s[i] = q[i];
    return s;
}

int main(){
    char q[] = "hello";
    char *s = cloning(q);
    return 0;
}

编译后出现警告,所以我将返回值改成这样:

char *b = s;
return b;

这样就可以解决warning了。但是我发现在函数 cloning() 中,sizeof(s) 是 5,而 strlen(s) 是 7。如果我将 char s[strlen(q)] 简单地更改为 char s[5],输出仍然是不正确。谁能向我解释这个问题?非常感谢。

最佳答案

char s[strlen(q)] 是一个局部变量,因此当您返回它的地址时,它会导致未定义的行为。因此,您可以使用 strdup()malloc() 来动态分配数组,从而确保当您从函数返回时数组 s 在堆上可用。返回的数组也需要被 free() 编辑,否则会发生内存泄漏:)

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char * cloning(char * q){
    char *s = malloc(strlen(q)+1);
    // if you write char s[strlen(q)], it is defined locally, and thus on return gives an undefined behaviour
    int i;
    for(i = 0; i < strlen(q)+1; i++)
        s[i] = q[i];
    return s;
}

int main(){
    char q[] = "hello";
    char *s = cloning(q);
    free(s);
    return 0;
}

关于c - 动态和静态字符数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16766648/

相关文章:

gcc中的C内存管理

c - 在 Mac OS X 上用 C 操作剪贴板

c - 如何使用二维数组使用c代码查找文件的尾部

java - 不在声明中时的数组初始化语法

c++ - 3d -> 1D 数组索引

Java JTextField 写入时转换为大写/小写

在像 printf() 这样的可变参数函数中,整数提升能否以相反的顺序发生(例如 long int 到 int)?

c - 为什么我的 Xcode 找不到我创建的 .txt 文件?

c - %[^\n] 和 %[^\n]s 有什么区别?

c - 为什么 getchar() 不起作用,但 getchar_unlocked() 在读取字符串字符时在 main 函数之外执行?