需要一个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)程序代码区。
实现方法:
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)程序代码区。
相关文章推荐
- 将浮点型数据转化为人民币读法字符串的方法(数组实现)
- JS实现数组去重方法总结(六种方法)
- JS解析json数据并将json字符串转化为数组的实现方法
- js实现数组去重的三个方法、数组的快速排序
- js巧用apply方法实现数组最值以及合并
- ECMA5数组的新增方法有哪些及forEach()模仿实现
- PHP is_array() 检测变量是否是数组的实现方法
- PHP 数组和字符串互相转换实现方法
- 矩阵或多维数组两种常用实现方法 - python
- foreach 仅需要类实现public IEnumerator GetEnumerator()方法而无需实现接口
- JavaScript实现将数组数据添加到Select下拉框的方法
- JS函数arguments数组获得实际传参数个数的实现方法
- php通过数组实现多条件查询实现方法(字符串分割)
- Windows批处理 实现数组方法
- 求一个整数数组的最大元素,用递归方法实现
- JavaScript基于对象方法实现数组去重及排序操作示例
- 通过hashmap实现统计字符串数组中某个字符串出现的次数的方法
- PHP简单实现合并2个数字键数组值的方法
- java数据结构与算法之双向循环队列的数组实现方法
- JavaScript中去掉数组中的重复值的实现方法