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

24 篇文章 1 订阅

今天在网上看到如题的一个帖子,觉得值得收藏一下

实现方法:

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) 从堆上分配,亦称动态内存分配。程序在运行的时候用mallocnew申请任意多少的内存,程序员自己负责在何时用freedelete来释放内存。动态内存的生存期由程序员自己决定,使用非常灵活。 

3) 从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量,static变量。 

4) 文字常量分配在文字常量区,程序结束后由系统释放。 

5)程序代码区。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值