写一个内存申请函数:以指针为目标,修改指针本身
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://www.cnblogs.com/greatIDeas/archive/2010/11/24/1886915.html
解决我的问题:动态申请二维数组
#include <iostream>
using namespace std;
template <class T>
void get2array(T ***ptr, const int &row, const int &column)
{
*ptr=new T *[row];
(*ptr)[0]=new T[row*column];
for(int i=1;i<row;++i)
(*ptr)[i]=(*ptr)[i-1]+column;
}
int main()
{
int row,column;
cin>>row>>column;
int **ptr;
get2array(&ptr,row,column);
for(int i=0;i<row;++i)
for(int j=0;j<column;++j)
cin>>ptr[i][j];
for(int i=0;i<row;++i)
for(int j=0;j<column;++j)
cout<<ptr[i][j]<<' ';
delete []ptr[0];//这里还不知道如何释放???
delete []ptr;
return 0;
}