Fortran Coder

计算中,大数组导致的内存不足

查看数: 23632 | 评论数: 5 | 收藏 0
关灯 | 提示:支持键盘翻页<-左 右->
    组图打开中,请稍候......
发布时间: 2015-1-24 18:18

正文摘要:

编写了一个程序,其中有12个四维数组,比如:u(6,100,100,204),v(6,100,100,204)等。因为计算需要,我把数组改写成了u(6,200,200,204)。编译时出现这个错误LNK1248: image size ('size') exceeds maximum allowable ...

回复

fcode 发表于 2015-1-25 20:02:04
任何时候,算法改进都是需要考虑的。而不是硬件条件不够了再考虑。
HXL31209 发表于 2015-1-25 18:46:56
楚香饭 发表于 2015-1-25 08:35
IVF 的 32 位和 64位是在一起安装的。即便你安装了,也需要切换到64位来编译。

你可以在工程属性之类的地 ...

谢谢,按照上面的方法。暂时解决了目前这个大小的数值。不过后面还想再加大数组,是不是得考虑算法改进,或者搞并行计算了。。。
楚香饭 发表于 2015-1-25 08:35:39
IVF 的 32 位和 64位是在一起安装的。即便你安装了,也需要切换到64位来编译。

你可以在工程属性之类的地方找到。

这些问题,都可参考这个帖子:
http://bbs.fcode.cn/thread-448-1-1.html
HXL31209 发表于 2015-1-24 22:11:35
fcode 发表于 2015-1-24 19:14
语法没有对数组大小进行限制,而限制来源于具体的操作环境。

6*200*200*204 = 48960000

果然是高手,解释的非常清楚,谢谢。我安装的是visual studio 2010版和IVF 2013. 下载的时候都是下载的64位的。但是从《Fortran 95 程序设计》【彭国伦】一书中P148页里面的小程序来计算我的电脑能承受2G的数组,从上面你的分析来看,离4.5G的需求,确实不够。本身是8G内存,如果按照你的建议。我在安装了合适的64位编译器之后,再开启最大数组地址支持,应该可以实现。
但是我现在的问题是:
1. 如何确定自己正确安装了64位编译器?
2.怎么开启最大数组地址支持?
fcode 发表于 2015-1-24 19:14:06
语法没有对数组大小进行限制,而限制来源于具体的操作环境。

6*200*200*204 = 48960000

因为是双精度的,每个数据8字节,所以一共 48960000*8 = 391680000 字节 = 382500 KB = 373.5 MB

12个这样的数组,一共 4482.4 MB,也就是 4.5GB

32位系统可以最大的寻址是 2**32 = 4GB,实际上 Windows 限定为 2GB,除去操作系统本身之外,实际可用的内存只有1.2GB左右。
64位系统则更大一些,但这需要你的编译器也是64位的。

具体可利用的内存还受其他因素影响。

楼主可尝试使用64位编译器编译,并开启大数组地址支持。或者考虑在算法上修改,提高内存重复使用率。

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-6-11 13:00

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表