各位大大好小弟是刚学程式不久的小鲁
最近在跑一支程式的时候,该程式的某个函数用malloc要了1000个double变量的空间
但是free掉指标之后还是可以读取里面的内容
请各位大大指点迷津> <
程式码如下
double find_k(int n, double eta)
{
int i, size=1000, ibest;
double lower, upper, al, g1, g2, step;
double y, ybest;
double *y;
lower = 0.;
upper = 1.-eta;
step = (upper-lower)/size;
y = (double *) malloc(size*sizeof(double));
for (i=1; i < size; i++) {
al = lower+step*i;
g1 =functionA(...);
g2 =functionB(...);
y = g2-g1;
y[i] = y;
}
ybest = 1000000.;
ibest = 1;
for (i=1; i < size; i++) {
if (y[i]< ybest) {
ybest = y[i];
ibest = i;
}
}
free(y);
printf("!!y[99]=%lf\n",y[99]);<<<<<<
al = lower+(double)ibest*step;
return al;
}
小弟的执行环境是win7 用的是dev C++;
如题目所说,用穷举的方式找出最小的y之后,将指向1000个变量空间的y给free掉
照理来讲printf("!!y[99]=%lf\n",y[99])这行叙述应该是跑不出东西的,
请各位大大帮小弟指点迷津@@