您的位置:首页 > 其它

需要一个1000000的数组实现方法

2010-03-18 09:31 274 查看
今天在网上看到如题的一个帖子,觉得值得收藏一下

实现方法:

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)程序代码区。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: