gpt4 book ai didi

c - 重复调用后 realloc() 失败

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

我正在用 C 语言实现一些多项式运算。我使用动态结构来存储整数因子和多项式次数。除了其他函数,我还需要操作 p[X]*X,所以我尝试实现某种右移。

但经过几次转换后,realloc() 使我的程序崩溃。在此示例中,它是在第三次调用时,但如果我尝试移动 2 次和 4 次,它会在第二次调用后崩溃。

/* Simple polynom type with variable length and degree n-1. */
typedef struct {
int n;
int *factors;
} polynom_t;


polynom_t *poly_init(int n) {
polynom_t *p_new = malloc(sizeof(polynom_t));
p_new->n = n;
p_new->factors = calloc(n, sizeof(int));

return p_new;
}

void poly_clear(polynom_t *p) {
free(p->factors);
free(p);
p = NULL;
}


void poly_set(polynom_t *p, int a[], int len){
memcpy(p->factors, a, sizeof(int)*p->n);
}


void _poly_rsz(polynom_t *p, int n) {
if (n != p->n) {
p->n = n;

// This realloc() seems to fail
p->factors = realloc(p->factors, sizeof(int) * n);
}
}


void _poly_lsr(polynom_t *p, int i) {
_poly_rsz(p, p->n + i);
memmove(p->factors + i, p->factors, sizeof(int)*(p->n));
memset(p->factors, 0, sizeof(int)*i);
}


int main(int argc, char **argv) {
polynom_t *p2 = poly_init(11);
int a2[11] = {1, 2, 0, 2, 2, 1, 0, 2, 1, 2, 0};
poly_set(p2, a2, 11);
_poly_lsr(p2, 1); // works as expected
_poly_lsr(p2, 1); // works as expected
_poly_lsr(p2, 1); // crash
poly_clear(p2);

return 0;
}

最佳答案

问题出在这段代码上:

void _poly_lsr(polynom_t *p, int i) {
_poly_rsz(p, p->n + i);
memmove(p->factors + i, p->factors, sizeof(int)*(p->n)); // the problem is here!
memset(p->factors, 0, sizeof(int)*i);
}

当您调整多项式的大小时,您会重置它的计数,这意味着,当您加 1 时,您会溢出多项式数组的边界 1。要修复,只需从中减去 i memmove 计数:

memmove(p->factors + i, p->factors, sizeof(int)*(p->n - i));

关于c - 重复调用后 realloc() 失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9538567/

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