使用 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));
不好。您只分配一个元素。看来你应该分配 N
和 D
元素。
此外,上面的第 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);
#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));
不好。您只分配一个元素。看来你应该分配 N
和 D
元素。
此外,上面的第 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);