来自http://blog.****.net/maverick1990/article/details/22829135
一维数组
动态分配,int *array = new int[10]
初始化,memset(array,0,sizeof(int)*10);
撤销,delete[] array
二维数组m行n列
int **d;
d = new int *[];
for(int i =;i<;i++){
d[i] = new int[]
}
先分配一个10单元的数组指针的指针的首地址给**d,然后对其每个首地址进行遍历,
完成一个5单元的数组的动态分配,并把首地址给*d[i],最后完成d[10][5]的动态分配。
怎么初始化二维数组?
void memset(void* dest,int c,size_t count)////
sets buffers to a specified character.
memset只能作用于一个一维数组的void *dest,因此最好的方法就是和二维数组的动态分配,
memset最好用来初始化数组为零,初始化bool数组
结合起来,new一个,memset一个。
例如:
int **d;
d = new int *[];
for(int i = ;i<;i++){
d[i] = new int[];
memset(d[i],,*sizeof(int));///当sizeof一个指针时,返回值为指针本身的大小而不是指针指向区域的大小,
///所以第三个要明确空间大小,不能sizeof(d[i]).
}
如何撤销?
for(int i = 0;i<10;i++){
delete[] a[i];
}
delete[] a;
=========================
来个例子,
class A{
public:
void test_memset(){
///============
int *d;
d = new int[];
memset(d,-,sizeof(int)*);
for(int i = ;i<;i++){
cout<<d[i]<<" ";
}cout<<endl;
delete[] d;
///==============
int **a;
a = new int*[];
for(int i = ;i<;i++){
a[i] = new int[];
memset(a[i],-,sizeof(int)*);
}
for(int i = ;i<;i++){
for(int j = ;j<;j++){
cout<<a[i][j]<<" ";
}cout<<endl;
}
for(int i = ;i<;i++){
delete[] a[i];
}
delete[] a; ///====================
int ***c;
c = new int**[];
for(int i = ;i<;i++){
c[i] = new int*[];
for(int j = ;j<;j++){
c[i][j] = new int[];
memset(c[i][j],-,sizeof(int)*);
}
} for(int i = ;i<;i++){
for(int j = ;j<;j++){
for(int k = ;k<;k++){
cout<<"i-j-k"<<i<<j<<k<<"~"<<c[i][j][k]<<" ";
}cout<<endl;
}cout<<endl<<endl;
}
///=========== for(int i = ;i<;i++){
for(int j = ;j<;j++){
delete[] c[i][j];
}
delete[] c[i];
}
delete[] c;
cout<<"destoryed done!"<<endl;
}
};