今天在网上看到如题的一个帖子,觉得值得收藏一下
实现方法:
1. 放在全局区
static int c[1000 * 1000];
2. 动态分配.
int *c;
c = malloc(sizeof(int) * 1000 * 1000);
#include<stdio.h>
#include<stdlib.h>
int main()
{
int *p = (int *)malloc(1000000*sizeof(int));
if(p) {
printf("success!/n");
}
else {
printf("failed!/n");
}
free(p);
return 0;
}
知识链接:堆和栈的区别
堆:
静态变量和全局变量一般存放在堆中,malloc函数申请的空间也是存放在堆中
栈:
子函数入口的临时变量和局部变量,这一类主要存放在栈中
1) 在栈上创建。在执行函数时,函数内局部变量的存储单元都在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,一般使用寄存器来存取,效率很高,但是分配的内存容量有限。
2) 从堆上分配,亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete来释放内存。动态内存的生存期由程序员自己决定,使用非常灵活。
3) 从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量,static变量。
4) 文字常量分配在文字常量区,程序结束后由系统释放。
5)程序代码区。