Fortran Coder

楼主: jovan
打印 上一主题 下一主题

[编译器] 自定义类型的内存占用巨大

[复制链接]

6

帖子

0

主题

0

精华

入门

F 币
57 元
贡献
30 点
11#
发表于 2015-12-7 12:18:01 | 只看该作者
虽然已经结贴,但我还是要说一下,楼主切不可以C的编程思想来写Fortran程序。要知道,C的数组是没有Shape信息的,面Fortran却有。那么一个数组需要多少空间存这些Shape信息呢?至少我们需要:
数组起始地址;(一个字长)
维度;(4字节)
每个维度又至少会有:
上标;(4字节)
下标;(4字节)
间隙:(4字节)
内存对齐保留处(4字节)—这部分可选,但一般都会有。
部分编译器实现还会在维度+1的地方有全0填充防侧漏。
这样一来,如果您的单个数组很小,但数组的数量却非常多,那内存占用就远远会超出你的预期。

对于一个计算问题,我们Fortran一般都是用单一数组解决,而不使用如此松散的方式存储。因为,只有批量操作才能显现Fortran计算的优越性,并且也便于编译器做优化。

评分

参与人数 1贡献 +5 收起 理由
fcode + 5 很给力!

查看全部评分

7

帖子

2

主题

0

精华

入门

F 币
33 元
贡献
19 点
12#
 楼主| 发表于 2015-12-9 11:47:25 | 只看该作者
是这样的,以之前的数据结构写的话,多余的内存占用不可避免,而且比数据本身需要占用的内存还大,造成了很大的浪费,谢谢你的提醒
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-12-24 02:49

Powered by Tencent X3.4

© 2013-2024 Tencent

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