按照一个整型数据占4个字节来算, 2M内存用来开数组, 最大也就开个52万左右, 我们的测试开了1000万, 显然是要爆掉的. 那么问题来了, 难道我们的C语言, 就TM只能提供区区50来万的数组空间吗? 别说50万, 就是1千万, 也不一定完全 够用呀. 当然不是, 上面只是C语言分配内存的默认方法, 也是最简单的方法,...
一维数组能开到 4 9909 9039 (四亿多)二维数组能开到 2 2340 (两万多)这个数据是我在自己电脑上用codeblocks运行测试得到的结果如果数组大小稍微超过上面的两个数字不会报错,但是测试输出最后一位输出为空如果数组大小超过上面两个数字很多,例如五亿,那么会报错,无法编译成功看了一下这个数据,大概...
理论上在不同平台不同机器上都可能不同。如果是栈上的数组,最大就是栈的大小,一般是1MB~8MB。如果是堆上的数组,最大就是堆的大小,一般32位机器大约是4GB,64位机器就是4G个4GB。
取决于物理系统剩余内存大小。在C语言中,malloc动态开辟的空间,以及静态数组均是占用堆上的内存的。而系统堆内存是与进程无关的,堆内存的剩余量,就是系统内存的剩余量,包括物理内存和虚拟内存。所以,只要系统内存剩余有多大,那么malloc和静态数组就可以开多大。不过,由于系统内存剩余量并非固定,而是...
C程序允许的最大char[]数组大小取决于编译器和操作系统的限制。在C语言中,数组的大小是由数据类型和可用内存空间决定的。 在大多数32位操作系统上,由于地址空间的限制,一个C程序允许的最大char...
用C语言定义全局数组的最大大小取决于编译器和操作系统的限制。在C语言中,全局数组的大小是由编译器和操作系统的限制确定的,通常受到可用内存的限制。 在32位操作系统上,由于地址空间的限制,全局数组的最...
想开大的数组,可以用动态分配。定态数组,作为全局量可以开得大。例如:include <stdio.h> int a[1001][1001]; // 全局量 main(){ a[1000][1000]=1000;printf("%d",a[1000][1000]);return 0;} 若放到 main(){} 里,就是局部量,就不能用这么多单元了。
在函数外定义数组试试,函数调用的时候会将变量分配在栈上,所以当数组太大的时候可能会出现栈溢出的情况,在函数外定义全局变量,可能会避免这种情况。
就要靠输入,来确定数组大小了。重点在于,要开辟多大的数组来存 一般有这么几种情况 1 直接开一个足够大的。 比如 虽然不知道有多大,但最大不超过1000个,那就可以直接开个1000元素的数组。2 动态分配, 使用malloc动态分配内存。当出现可能的不够情况,用realloc重新分配。