在保存有条件分配的内存的指针上使用 free 时,程序有时会崩溃
Program crashes at times while using free on a pointer which holds conditionally allocated memory
这是一个简单的代码,只是为了说明我正在处理的问题。
如果你给出n = 3和的输入,输入数组元素为1, 2 ,3和m= 0程序崩溃!!!
为什么会这样??由于 最后两行涉及 free()
现在我的问题是为什么会发生这种情况?如果删除自由语句,具有相同输入的相同程序不会崩溃...
请解释一下。 是否是条件内存分配导致上述问题发生?如果是,那为什么?
我没有得到任何提示,而且据我所知,free (NULL) 不会导致任何错误,所以问题是在我尝试释放分配的内存之一时引起的,尤其是 positive 在我的输入中...
这是我的代码:
#include <stdlib.h>
#include <stdio.h>
int main()
{
int n;
scanf("%d",&n);
printf("Enter elements into the array\n");
int arr[n];
int i;
for(i=0;i<n;)
{
printf("arr[%d] ? ",i);
scanf("%d",(arr+i));
if(i>0)
{
if(arr[i]<arr[i-1])
continue;
else
i++;
}
else
i++;
}
int m;
printf("m ? ");
scanf("%d",&m);
int j,flag=0;
int *positive,*negative;
int start,end;
start=arr[0];
end=arr[n-1];
if(start<0 && end<0)
{
negative=(int*)calloc((start*-1),sizeof(int));
positive=0;
}
else if(start<0 && end>0)
{
negative=(int*)calloc((start*-1),sizeof(int));
positive=(int*)calloc(end,sizeof(int));
}
else if(start>=0 && end >0)
{
negative=0;
positive=(int*)calloc(end,sizeof(int));
}
int p=0;
for(i=0;i<n;i++)
{
if(i==0)
p=-1;
else
p=i;
if(arr[i]<0)
negative[-arr[i]]=p;
else
positive[arr[i]]=p;
}
for(i=0;i<n;i++)
{
int num=m-arr[i];
if(negative!=0 && num<0 && negative[-num])
{
if(negative[-num]==-1)
j=0;
else
j=negative[-num];
printf("%d %d\n",i,j);
flag=1;
}
else if(positive!=0 && num>=0 && positive[num])
{
if(positive[num]==-1)
j=0;
else
j=positive[num];
printf("%d %d\n",i,j);
flag=1;
}
}
if(flag==0)
printf("NO SUCH i j EXISTS\n");
if(positive) free(positive);
if(negative) free(negative);
return 0;
}
这是我的输出:
根据您提到的输入值,您首先要做的是:
end=arr[n-1];
positive=(int*)calloc(end,sizeof(int));
鉴于 n == 3
和 arr[n-1] == 3
,您为 positive
.
分配了一个 3 int
的数组
在紧接着的下一个循环中,您最终会做:
positive[arr[i]]=p;
试图覆盖 positive[3]
(当 i == n-1
时)。这是试图超出数组的边界(有效索引范围仅从 0
到 2
),并且 undefined behavior 随之而来,这意味着在那之后任何事情都可能发生,包括崩溃。
这是一个简单的代码,只是为了说明我正在处理的问题。
如果你给出n = 3和的输入,输入数组元素为1, 2 ,3和m= 0程序崩溃!!!
为什么会这样??由于 最后两行涉及 free()
现在我的问题是为什么会发生这种情况?如果删除自由语句,具有相同输入的相同程序不会崩溃...
请解释一下。 是否是条件内存分配导致上述问题发生?如果是,那为什么?
我没有得到任何提示,而且据我所知,free (NULL) 不会导致任何错误,所以问题是在我尝试释放分配的内存之一时引起的,尤其是 positive 在我的输入中...
这是我的代码:
#include <stdlib.h>
#include <stdio.h>
int main()
{
int n;
scanf("%d",&n);
printf("Enter elements into the array\n");
int arr[n];
int i;
for(i=0;i<n;)
{
printf("arr[%d] ? ",i);
scanf("%d",(arr+i));
if(i>0)
{
if(arr[i]<arr[i-1])
continue;
else
i++;
}
else
i++;
}
int m;
printf("m ? ");
scanf("%d",&m);
int j,flag=0;
int *positive,*negative;
int start,end;
start=arr[0];
end=arr[n-1];
if(start<0 && end<0)
{
negative=(int*)calloc((start*-1),sizeof(int));
positive=0;
}
else if(start<0 && end>0)
{
negative=(int*)calloc((start*-1),sizeof(int));
positive=(int*)calloc(end,sizeof(int));
}
else if(start>=0 && end >0)
{
negative=0;
positive=(int*)calloc(end,sizeof(int));
}
int p=0;
for(i=0;i<n;i++)
{
if(i==0)
p=-1;
else
p=i;
if(arr[i]<0)
negative[-arr[i]]=p;
else
positive[arr[i]]=p;
}
for(i=0;i<n;i++)
{
int num=m-arr[i];
if(negative!=0 && num<0 && negative[-num])
{
if(negative[-num]==-1)
j=0;
else
j=negative[-num];
printf("%d %d\n",i,j);
flag=1;
}
else if(positive!=0 && num>=0 && positive[num])
{
if(positive[num]==-1)
j=0;
else
j=positive[num];
printf("%d %d\n",i,j);
flag=1;
}
}
if(flag==0)
printf("NO SUCH i j EXISTS\n");
if(positive) free(positive);
if(negative) free(negative);
return 0;
}
这是我的输出:
根据您提到的输入值,您首先要做的是:
end=arr[n-1];
positive=(int*)calloc(end,sizeof(int));
鉴于 n == 3
和 arr[n-1] == 3
,您为 positive
.
int
的数组
在紧接着的下一个循环中,您最终会做:
positive[arr[i]]=p;
试图覆盖 positive[3]
(当 i == n-1
时)。这是试图超出数组的边界(有效索引范围仅从 0
到 2
),并且 undefined behavior 随之而来,这意味着在那之后任何事情都可能发生,包括崩溃。