使用 realloc 在动态字符串中中止(核心转储)

Aborted(core dumped) in dynamic string with realloc

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
int Init_Arr(int N,int X,int *arr);

void Add_elem(int N,int *arr);

void Del_elem(int N,int *arr);

void Reinit_arr(int N,int *arr);

int main(){
  int N,X,*arr;
  printf("How big array do you want?:");
  scanf("%d",&N);
  arr=(int *)malloc(sizeof(N));
  printf("\nHow much elements do you want in your array?:");
  scanf("%d",&X);
  Init_Arr(N,X,arr);
  Add_elem(N,arr);
  Del_elem(N,arr);
  Reinit_arr(N,arr);
  return 0;
}
int Init_Arr(int N,int X,int *arr){
  for (int i=0;i<N;i++){
    arr[i]=0;
  }
  for(int i=0;i<X;i++){
    arr[i]=rand()%10+1;
  }
  for(int i=0;i<N;i++){
    printf("%d",arr[i]);
  }
  printf("\nArray is initialised!\n");
  return 0;
}

void Add_elem(int N,int *arr){
  int add;
  int help;
  int i=0;
  printf("\nWhat element do you want to add?:");
  scanf("%d",&add);
  while(arr[i]!=0){
    i++;
  }
  arr[i]=add;
  for(int i=0;i<N;i++){
    printf("%d",arr[i]);
  }
  printf("\nElement was added to array!\n");
}
void Del_elem(int N,int *arr){
  int del;
  printf("\nWhat element do you want to delete from array?:");
  scanf("%d",&del);
  arr[del]=0;
  for(int i=0;i<N;i++){
    printf("%d",arr[i]);
  }
  printf("\nElement was deleted from array!\n");
}
void Reinit_arr(int N,int *arr){
  int *copyarr;
  int D;
  copyarr=(int *)realloc(sizeof(N));
  for(int i=0;i<N;i++){
    copyarr[i]=arr[i];
  }
  printf("How big array now do you want?:");
  scanf("%d",&D);
  arr=(int*)realloc(arr,sizeof(D));
  for(int i=0;i<N;i++){
    arr[i]=copyarr[i];
  }
  for(int i=N;i<D;i++){
    arr[i]=0;
  }
  for(int i=0;i<D;i++){
    printf("%d",arr[i]);
  }
  printf("\nArray was reinitialised\n");
}

嗯,这个程序应该在way:initiate后面工作一个动态字符串,用X个随机元素填充它,然后将任何元素添加到正数字符串的末尾,删除任何元素(只需将其设置为0) 数组和问题 function:reallocate 内存并使字符串变大,并复制内部。问题是它只是在函数

中说“中止”
Reinit_arr(N,arr);

GDB 说在尝试这个函数后程序返回 following:raise.c: 没有那个文件或目录。你能帮我吗?

线条

arr=(int *)malloc(sizeof(N));
copyarr=(int *)realloc(sizeof(N));
arr=(int*)realloc(arr,sizeof(D));

不好。您只分配一个元素。看来你应该分配 ND 元素。

此外,上面的第 2 行只为 realloc() 指定了一个参数,而它需要两个参数。看起来你的意思是 malloc().

最后,malloc()家族的选角结果是considered as a bad practice

总之,这些行应该是:

arr=malloc(sizeof(*arr)*N);
copyarr=malloc(sizeof(*copyarr)*N);
arr=realloc(arr,sizeof(*arr)*D);