malloc的申请方式很容易理解:
char **pchar = NULL;
pchar = (char **)malloc(n*sizeof(char *));/pchar其实就是一个char* []数组
//现在可以在这里给数组元素赋值
pchar[0] = (char *)malloc(SIZE * sizeof(char));//或*(p+0)
pchar[1] = (char *)malloc(SIZE * sizeof(char))// 或*(p+1)
....
用new实现:
int **p;
cin>>n>>m;
p=new int* [n];//先申请全部行首(n行)指针,再按行逐行申请
for(i=0;i<n;i++)
p[i]=new int [m];
一定注意new返回的是个指针
千万不要自作聪明,认为下面的语句更直观
int *p[]=new int *[n];
new返回的是个指针,无法为数组赋初值,所以上面的语句无法编译通过
用new实现唯一不好理解的就是 new int *[n];
*是放在int之后,数组标志(暂且这么称呼那个中括号吧)之前的,其实也没什么不好理解的,毕竟我们见到的简单指针声明时,*都是在类型之后的。
//指针数组说完了,简单说下某次*面试遇到的指针问题
char a[]="";//没有空格
char *p=a;
char *q=NULL;
这里a,p,q是完全不同的:
a表示一个空串,sizeof(a)=1;即只有一个'\0'字符
p是指向a的指针,它的值和a是相同的,但是sizeof(p)却是4,因为它是个指针
q是个空指针,所以sizeof(q)=4,但是*q和*p是完全不一样的。
在用cout输出*a和*p是,相当于输出一个空格
但是cout<<*q; 却会出现程序错误
即使是cout<<q;也会出现运行时的错误
不过编译都能通过
另外sizeof(NULL) 结果也为4;
直接cout<<NULL;结果为0;