#include <stdio.h>
#define MAXNODE 10
int *c;
void test1(int **b)
{
*b=new int[MAXNODE];
}
void test2()
{
c=new int[MAXNODE];
}
void main()
{
int *a;
int i=0;
test1(&a);
test2();
for(i=0;i<MAXNODE;i++)
{
c[i]=i;
a[i]=i+1;
}
for(i=0;i<MAXNODE;i++)
printf("c[i]=%d ",c[i]);
printf("/n");
for(i=0;i<MAXNODE;i++)
printf("a[i]=%d ",a[i]);
for(i=0;i<MAXNODE;i++)
{
*(a+i)=0;
*(a+i)=i;
*(c+i)=0;
*(c+i)=i;
}
printf("/n");
for(i=0;i<MAXNODE;i++)
printf("c[i]=%d ",*(c+i));
printf("/n");
for(i=0;i<MAXNODE;i++)
printf("a[i]=%d ",*(a+i));
}
以上编译可以通过,且可以输出正确结果,编译环境为vc++6.0 以上*a为局部变量,test1(int **b)函数中的**b编译器将在函数的堆栈上为**b分配空间. 此处b中存放了a的地址.