c - 二维动态字符串数组 realloc 导致错误

标签 c arrays memory dynamic segmentation-fault

所以我试图重新分配一个二维字符数组,但它总是失败 我有 stdlib.h 包括在内,我仍然尝试使用强制转换以防万一,但还是出现了同样的错误。 我认为错误是当我写(使用 strcpy )

这实际上只是一个辅助测试程序,因为我无法获得另一个处理二维数组增长的程序。我在 strcpy

时遇到段错误
int main()
{
  char** rec = malloc(10* sizeof(char*));;
  char** arr = malloc(10* sizeof(char*));
  char a = 'a';
  char *c = &a;

  for ( int i =0; i < 10; i++){
    rec[i] = malloc(10*sizeof(char));
    strcpy(rec[i], c);
    arr[i] = malloc(10*sizeof(char));
    strcpy(arr[i], c);
  }

  rec = realloc(rec, 20* sizeof(char*));
  for (int i =0; i< 20; i++) 
    rec[i] = realloc(rec, 10*sizeof(char));

  arr = realloc(arr, 20* sizeof(char*));
  for (int i = 0; i < 20; i++) 
    arr[i] = realloc(arr, 10*sizeof(char));

  for ( int i =0;i< 10; i++ ) {
    free(rec[i]);
    free(arr[i]);
  }
  free(rec);free(arr);
}

这给了这个坏男孩

*** glibc detected *** ./HW1: realloc(): invalid next size: 0x00000000023d0350 ***
======= Backtrace: =========
/lib/x86_64-linux-gnu/libc.so.6(+0x75be6)[0x7f1150953be6]
/lib/x86_64-linux-gnu/libc.so.6(+0x7b8bc)[0x7f11509598bc]
/lib/x86_64-linux-gnu/libc.so.6(realloc+0xf0)[0x7f1150959bd0]
./HW1[0x40070b]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xfd)[0x7f11508fcead]
./HW1[0x400509]
======= Memory map: ========
00400000-00401000 r-xp 00000000 00:2c 8904345153                         /import/linux/home/jkim332/cs220/HW1/HW1
00600000-00601000 rw-p 00000000 00:2c 8904345153                         /import/linux/home/jkim332/cs220/HW1/HW1
023d0000-023f1000 rw-p 00000000 00:00 0                                  [heap]
7f114c000000-7f114c021000 rw-p 00000000 00:00 0
7f114c021000-7f1150000000 ---p 00000000 00:00 0
7f11506c8000-7f11506dd000 r-xp 00000000 00:10 4345426042                 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f11506dd000-7f11508dd000 ---p 00015000 00:10 4345426042                 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f11508dd000-7f11508de000 rw-p 00015000 00:10 4345426042                 /lib/x86_64-linux-gnu/libgcc_s.so.1
7f11508de000-7f1150a5f000 r-xp 00000000 00:10 4343317221                 /lib/x86_64-linux-gnu/libc-2.13.so
7f1150a5f000-7f1150c5f000 ---p 00181000 00:10 4343317221                 /lib/x86_64-linux-gnu/libc-2.13.so
7f1150c5f000-7f1150c63000 r--p 00181000 00:10 4343317221                 /lib/x86_64-linux-gnu/libc-2.13.so
7f1150c63000-7f1150c64000 rw-p 00185000 00:10 4343317221                 /lib/x86_64-linux-gnu/libc-2.13.so
7f1150c64000-7f1150c69000 rw-p 00000000 00:00 0
7f1150c69000-7f1150c89000 r-xp 00000000 00:10 4345380830                 /lib/x86_64-linux-gnu/ld-2.13.so
7f1150e55000-7f1150e58000 rw-p 00000000 00:00 0
7f1150e86000-7f1150e88000 rw-p 00000000 00:00 0
7f1150e88000-7f1150e89000 r--p 0001f000 00:10 4345380830                 /lib/x86_64-linux-gnu/ld-2.13.so
7f1150e89000-7f1150e8a000 rw-p 00020000 00:10 4345380830                 /lib/x86_64-linux-gnu/ld-2.13.so
7f1150e8a000-7f1150e8b000 rw-p 00000000 00:00 0
7fff359d6000-7fff359f7000 rw-p 00000000 00:00 0                          [stack]
7fff359f8000-7fff359fa000 r-xp 00000000 00:00 0                          [vdso]
7fff359fa000-7fff359fc000 r--p 00000000 00:00 0                          [vvar]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0                  [vsyscall]

最佳答案

strcpy 要求源字符串(右边那个)是指向以 NUL 结尾的字符数组的指针。

但是 'a' 是单个字符,不是以 NUL 结尾的字符数组。

如果只是移动单个字符,请使用 'arr[i] = *c;'或者,为了清楚起见, 'arr[i] = a;'

但是,这会破坏指向已分配内存的指针。

如果你想用'a'填充分配的内存,那么使用

memset(arr[i], 'a', 10);

如果您只想设置 *arr[i] 数组中的第一个字符,则使用

*arr[i] = a;或者 *arr[i] = 'a';

(注意,用无意义的名称命名变量,例如发布的代码,会使代码更难阅读。)

这段代码:

rec = realloc(rec, 20* sizeof(char*));
for (int i =0; i< 20; i++) 
    rec[i] = realloc(rec, 10*sizeof(char));

将适用于原来的 10 行,但新行将 包含垃圾指针。

因此新行将需要一个 malloc 来设置那些指针 10...19 以指向分配的内存。

事实上,前 10 行会很好地重新分配,但最后 10 行(还)不是有效指针,因此在最后 10 行上调用 realloc 是未定义的行为,至少会破坏堆和 可能导致段错误事件。

关于c - 二维动态字符串数组 realloc 导致错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29688717/

相关文章:

c - 将二进制文件读入 char* 并转换为结构体?

c - C语言中基本数据类型的指针如何递增?

c - 我正在尝试编写一个函数,从给定的链表中删除所有奇数元素并返回一个地址

c - libmcrypt 不可靠吗?

java - 如何将数组和字符串匹配在一起并输出匹配数?

javascript - 使用正则表达式将 JS 中的大字符串文字解析为对象数组

c - 如何让一个函数返回正确的值?

c++ - 为什么有些函数需要作为DLL文件注入(inject)才能工作

c - C语言中的字符串引用

c# - C#中一个小类的内存优化