array 是 int * * 型的吗?我在VC6.0测试,分配内存是正确的,但要明白,分配的内存都被认为是int*型的,也就是101个int*型的空间。
*(array+j)得到这101个空间中的某个,是int*型,*(*(array+j)+n)是这101个指针中的某一个指向的内存空间,而这个内存空间没有分配,所以程序运行时会出错。至于在16位机器上通过,只是侥幸而已,因为16位机器没有内存保护,所有的空间都能访问,如果访问了操作系统的空间,可能不会立即崩溃,但系统有可能出问题的。而32位机器有保护模式,访问非法空间系统会报错。
首先:int** 是一个二级指针,它是指针的指针,如果你要申请一个二维数组,有下面两个方法:
int** val = (int**)malloc(sizeof(int*) * 10);
int i;
for(i = 0; i < 10)
val[i] = (int*)malloc(sizeof(int) * 10);
然后你可以这样引用:*(*(val+m)+n) = value;
第二种:int* val = (int*)malloc(sizeof(int) * 10 * 10);
然后这样引用:*(m*10 + n) = value;
这其实就是个一维数组,不过你把它看成二维的处理。。
希望对你有帮助哦
使用sizeof,就和机器位数无关~
二级指针动态分配方式如下:
int **a;
a=(int**)malloc(m*sizeof(int*));
for(i=0;i
1、void* malloc(size_t size)。这个函数请求分配大小为size字节的内存,并返回指向该块内存起始位置的指针。
2、例程:
#include
#include
void main()
{
int i,j;
int row,col;
int** matrix;
printf("input the row and col:\n");
scanf("%d%d",&row,&col); //输入矩阵的行和列
//动态分配内存
// 为动态数组分配了二维的空间
matrix=(int **)malloc(sizeof(int *)*row);
for(i=0;i{
matrix[i]=(int*)malloc(sizeof(int)*col);
}
//输入
printf("please input the array elements:\n") ;
for(i=0;i{
for(j=0;j{
scanf("%d",&matrix[i][j]);
}
}
//输出
for(i=0;i{
printf("\n");
for(j=0;j{
printf("%d ",matrix[i][j]);
}
}
}