C语言 关于为指针的指针分配内存的问题
int**val=NULL;我想为这个指针的指针分配内存;这样是不是对的?array=(int**)malloc(sizeof(int)*10*10+1);下面这段代码在...
int **val = NULL;
我想为这个指针的指针分配内存;
这样是不是对的?
array = ( int ** ) malloc( sizeof( int ) * 10 * 10 + 1 );
下面这段代码在16位的编译器上可以通过,但是在32位的VC6上就出错;
为什么?
for( n = 0 ; n < 10 ; n++ ) {
for( j = 0 ; j < 10 ; j++ ) {
*( *( array + j ) + n ) = j;
}
}
for( n = 0 ; n < 10 ; n++ ) {
for( j = 0 ; j < 10 ; j++ ) {
printf(" %d " , *( *( array + j ) + n ) );
}
printf("\n\n");
} 展开
我想为这个指针的指针分配内存;
这样是不是对的?
array = ( int ** ) malloc( sizeof( int ) * 10 * 10 + 1 );
下面这段代码在16位的编译器上可以通过,但是在32位的VC6上就出错;
为什么?
for( n = 0 ; n < 10 ; n++ ) {
for( j = 0 ; j < 10 ; j++ ) {
*( *( array + j ) + n ) = j;
}
}
for( n = 0 ; n < 10 ; n++ ) {
for( j = 0 ; j < 10 ; j++ ) {
printf(" %d " , *( *( array + j ) + n ) );
}
printf("\n\n");
} 展开
5个回答
展开全部
array 是 int * * 型的吗?我在VC6.0测试,分配内存是正确的,但要明白,分配的内存都被认为是int*型的,也就是101个int*型的空间。
*(array+j)得到这101个空间中的某个,是int*型,*(*(array+j)+n)是这101个指针中的某一个指向的内存空间,而这个内存空间没有分配,所以程序运行时会出错。至于在16位机器上通过,只是侥幸而已,因为16位机器没有内存保护,所有的空间都能访问,如果访问了操作系统的空间,可能不会立即崩溃,但系统有可能出问题的。而32位机器有保护模式,访问非法空间系统会报错。
*(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;
这其实就是个一维数组,不过你把它看成二维的处理。。
希望对你有帮助哦
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<m;i++)
a[i]=(int*)malloc(n*sizeof(int));
二级指针动态分配方式如下:
int **a;
a=(int**)malloc(m*sizeof(int*));
for(i=0;i<m;i++)
a[i]=(int*)malloc(n*sizeof(int));
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1、void* malloc(size_t size)。这个函数请求分配大小为size字节的内存,并返回指向该块内存起始位置的指针。
2、例程:
#include <stdio.h>
#include <stdlib.h>
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<row;i++)
{
matrix[i]=(int*)malloc(sizeof(int)*col);
}
//输入
printf("please input the array elements:\n") ;
for(i=0;i<row;i++)
{
for(j=0;j<col;j++)
{
scanf("%d",&matrix[i][j]);
}
}
//输出
for(i=0;i<row;i++)
{
printf("\n");
for(j=0;j<col;j++)
{
printf("%d ",matrix[i][j]);
}
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2010-01-09
展开全部
//给你一段代码看看,呵呵。
int i=0,j=0,x=10,y=10;
int **array=NULL;
//注意,是这样申请空间的,一次性完成
array=(int**)malloc(sizeof(int)*x*y + y*sizeof(int*));
array[0]=(int*)((char*)array + y*sizeof(int*));
for(i=1;i<y;i++)array[i]=array[i-1]+x;
for( i = 0 ; i < y; i++ )
{
for( j = 0 ; j < x; j++ )
{
array[i][j] = j;
}
}
for( i = 0 ; i < y; i++ )
{
for( j = 0 ; j < x; j++ )
{
printf(" %d " , array[i][j]);
}
}
free(array);//注意,是这样释放空间的,一次性完成
int i=0,j=0,x=10,y=10;
int **array=NULL;
//注意,是这样申请空间的,一次性完成
array=(int**)malloc(sizeof(int)*x*y + y*sizeof(int*));
array[0]=(int*)((char*)array + y*sizeof(int*));
for(i=1;i<y;i++)array[i]=array[i-1]+x;
for( i = 0 ; i < y; i++ )
{
for( j = 0 ; j < x; j++ )
{
array[i][j] = j;
}
}
for( i = 0 ; i < y; i++ )
{
for( j = 0 ; j < x; j++ )
{
printf(" %d " , array[i][j]);
}
}
free(array);//注意,是这样释放空间的,一次性完成
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询