我们知道在创立一个数组时,可以通过静态定义或动态分配来完成:
静态定义的数组在程序加载的时候(就是在你打开.cpp程序时)就已经分配好了内存空间,直到函数结束或者程序结束后才会被释放;而动态定义(比如malloc定义)的数组,在程序运行到相应代码行时才会申请内存空间,并且使用完后可以手动释放。
这一点我们会在后续的测试中体现出来。
先介绍malloc函数。
malloc() 函数用来动态地分配内存空间,其原型为:
void* malloc (size_t size);
保存在头文件stdlib.h中,所以要使用malloc函数时记得加#include
【参数说明】:size 为需要分配的内存空间的大小,以字节(Byte)计。在实际使用中,通常应用sizeof()函数来让计算机计算,省去计算的不便,例如:
int *a=(int *)malloc(n*sizeof(int));
便分配了连续的n个int大小的存储空间。
【函数说明】:malloc() 在堆区分配一块指定大小的内存空间,用来存放数据。这块内存空间在函数执行完成后不会被初始化,它们的值是未知的。如果希望在分配内存的同时进行初始化,请使用calloc函数。
【返回值】分配成功返回指向该内存的地址,失败则返回 NULL。注意:
函数的返回值类型是 void *,void 并不是说没有返回值或者返回空指针,而是返回的指针类型未知(或者说未确定)。所以在使用 malloc() 时通常需要进行强制类型转换,将 void 指针转换成我们希望的类型,指向该内存的地址,失败则返回 NULL。比如:
char *m=(char *)malloc(n*sizeof(char)); //这里的(char*)表示强制类型转换,将void*指针转变为了char*类型
放上两段代码:
//使用malloc动态分配数组 #include#include //引入头文件 int main(void){ int n,i; printf("想要输入几个数字?:"); scanf("%d",&n); i=n; int *a=(int *)malloc(sizeof(int)*(n+1)); //申请的内存空间为n+1个,使a【0】位置不存放数据 if(a){//如果分配空间成功 while(i--){ scanf("%d",(a+n-i+1));//这里的a+n-i+1表示数组元素a[n-i+1]的地址 } printf("输入成功!"); for(int j=1;j 以及两次测试结果: (编译了两次)
想要输入几个数字?:2 3 7 输入成功!3 7 a[0]=12915712 -------------------------------- Process exited after 21.26 seconds with return value 0 请按任意键继续. . .想要输入几个数字?:2 3 7 输入成功!3 7 a[0]=8393728 -------------------------------- Process exited after 7.002 seconds with return value 0 请按任意键继续. . .//静态分配数组测试 #includeint main(void){ int a[100]; int n; printf("想要输入几个数?:"); scanf("%d",&n); a[n+1]=''; for(int i=1;i<=n;i++){ scanf("%d",&a[i]); } printf("输入成功!"); for(int j=0;j 以及测试结果:(不论输入什么,没有初始化过的a[0]的值始终相同)
想要输入几个数?:2 3 7 输入成功!3 7 a[0]=101 -------------------------------- Process exited after 3.207 seconds with return value 0 请按任意键继续. . .
初次写作,多多指教~
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)