gpt4 book ai didi

c - 重新分配(): invalid next size: followed by a 32bit register

转载 作者:行者123 更新时间:2023-12-01 22:45:29 24 4
gpt4 key购买 nike

所以我一直在用 C 编写一个 mtf 编码器,但无论我做什么,我都遇到了 realloc() 错误。我已经检查过我的逻辑是否有错误(并且可能有),方法是使用打印语句查看我是否越界了我当前 malloc 的数组(添加一个超过我原始数组大小的字符串)这似乎不是问题所在。我使用过 GDB 和 Valgrind,当 Valgrind 遇到段错误时,GDB 给了我一条神秘的消息。这是我第一次使用动态内存,我对问题出在哪里感到很困惑,下面是我的代码以及 GDB 错误:

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

int count = 0;


move_to_front(int index, char** words){
int i;
char *t = words[index];

for(i = index; i>1; i--){
words[i] = words[i-1];
}

words[1] = t;

}


char** reallocate_words(char** words, int* words_size_pointer){
printf("We're entering here\n");
printf("%d", *words_size_pointer);
int temp = *words_size_pointer;
char** tempor;
temp = temp*2;
printf("%d", temp);
tempor = (char**) realloc(words, temp);
int i = *words_size_pointer;
for(i; i<temp; i++){
tempor[i] = (char*) malloc(120);
}
words_size_pointer = &temp;
return tempor;

}

void encode_word(int* words_size_pointer, FILE *f, char* word, char** words){
if(count == 0){
words[1] = word;
fputs(words[1], f);
count++;
}
int i;
for(i=0; i<=count; i++){
if(strcmp(words[i], word) == 0){
break;
}
}
if(i>=(*words_size_pointer)){
printf("%d\n", i);
words = reallocate_words(words, words_size_pointer);
words[count+1] = word;
count++;
fputc(count+128, f);
fputs(words[count], f);
move_to_front(count, words);
}
if(i>count){
words[count+1] = word;
count++;
fputc(count+128, f);
fputs(words[count], f);
move_to_front(count, words);
}
else{
fputc(i+128, f);
move_to_front(i, words);
}



}

void sep_words(char** words, char *line, int* words_size_pointer, FILE *f){
char* x;
int i = 0;
x = strtok(line, " ");
while(x != NULL){
encode_word(words_size_pointer,f, x, words);
x = strtok(NULL, " ");
}
}


void readline(FILE *f_two, FILE *f, char** words, int* words_size_pointer){
char *line;
size_t len = 0;
ssize_t temp;
int count;
do{
temp = getline(&line,&len,f);
printf("%s", line);
if(temp!= -1){
sep_words(words, line, words_size_pointer, f_two);

}
}while(temp!=-1);

}


int main(int argc, char *argv[]){
int x;
int i;
int j;
x = strlen(argv[1]);
char fi[x];
char mtf[3] = "mtf";
FILE *f;
FILE *f_two;
for(j = 0; j<(x-3); j++){
fi[j] = argv[1][j];
}
strcat(fi, mtf);
f = fopen(argv[1], "r");
f_two = fopen(fi, "w");
fputc(0xFA, f_two);
fputc(0XCE, f_two);
fputc(0XFA, f_two);
fputc(0XDF, f_two);
if(f == NULL){
return 1;
}

char** words;
words = (char **) malloc(20);
for(i = 0; i<20; i++){
words[i] = (char*) malloc(120);
}
int words_size = 20;
int* words_size_pointer = &words_size;

readline(f_two, f, words, words_size_pointer);
return 0;
}

至于 GDB 错误:

    *** Error in `/file_loc/mtfcoding2': realloc(): invalid next size: 0x0000000000603490 ***
2040 \\This is due to print statements within my function.
Program received signal SIGABRT, Aborted.
0x00007ffff7a4acc9 in __GI_raise (sig=sig@entry=6)
at ../nptl/sysdeps/unix/sysv/linux/raise.c:56
56 ../nptl/sysdeps/unix/sysv/linux/raise.c: No such file or directory.

感谢您的宝贵时间! :)

最佳答案

mallocrealloc 需要字节数 作为参数。但是,您正在编写如下代码:

char** words;
words = (char **) malloc(20);
for(i = 0; i<20; i++){
words[i] = (char*) malloc(120);

您分配了 20 字节,但随后您编写了 20 个指针(这可能需要 80 字节)。要解决此问题,您需要计算存储 20 个指针需要多少字节。执行此操作的安全方法是 use malloc as recommended by SO :

words = malloc(20 * sizeof *words);

您在 realloc 调用中遇到了同样的问题。


此行无效:words_size_pointer = &temp;。也许你的意思是 *words_size_pointer = temp; 。确保您清楚地了解这两行之间的区别。

注意。可能还有其他错误。

关于c - 重新分配(): invalid next size: followed by a 32bit register,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29311916/

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