写一个函数,让这个函数通过指针参数返回内存某一个缓冲区的首地址。
下面这段代码是正确的,这段代码通过函数申请一片内存区,并将申请到的内存首地址返回给调用函数:
void getptr(int **p, int num)
{
*p=(int *)maccol(num*sizeof(int));
return;
}
void main()
{
int *ptr;
int k;
getptr(&ptr,10);
for(k=0;k<10;k++)
{
scanf("%d",&ptr[k]);
}
}
------------------------------------------------------------------------------------------------
下面这样是不行的,无法得到返回的内存地址:
void getptr(int *p,int num)
{
p=(int *)maccol(num*sizeof(int)); return;
}
void main()
{
int *ptr;
int k;
getptr(ptr, 10);
for(k=0;k<10;k++)
{
scanf("%d",&ptr[k]);
}
}
原因:
首先要说明的是int *ptr,这时候ptr指向一个不明确的地址,在这种情况下getptr(ptr,10);这一句传一个地址给getptr里面的p指针,这时候p指针获得的是ptr指针的一个副本,确切的说是ptr指向的对象的内存地址,所以这种方式在函数里面可以用来传一个指针指向的数据,这个数据是引用,但是指针还是副本,就是p与ptr两个所指的数据是一样的,但是两个在内存的地址是不一样的. 而你这个程序要求的是给ptr动态分配内存,所以当分配了一块的内存,并且这个内存的首地址赋给p,这时候p指向的东西改变了,但没有影响到ptr指针.ptr指针指向的还是他原来的数据,只是p指针的数据改变了. 所以这种情况引入一个指针的指针,让p指针指向ptr这个指针(而不是ptr的副本),这时候动态的分配的数据块传给*p,这个*p就是ptr,所以给ptr分配内存成功。
详细情况参照博客:http://blog.csdn.net/fjb2080/article/details/5623427