Fortran Coder

查看: 9463|回复: 7
打印 上一主题 下一主题

[Module] module中定义怎么指定大小的数组

[复制链接]

13

帖子

5

主题

0

精华

入门

F 币
87 元
贡献
50 点
跳转到指定楼层
楼主
发表于 2014-10-9 22:57:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 凹小马 于 2014-10-9 23:00 编辑

提示错误如下:

An automatic object must not appear in the specification part of a module.
对应源码如下:
[Fortran] 纯文本查看 复制代码
MODULE module_slvr

!*****************************************************************************80
!
   USE module_defi_array, only : ncv
   IMPLICIT NONE

   REAL(kind=DBL), DIMENSION(2,2,ncv) :: ma

CONTAINS



我在查找到的错误分析如下:
由于编译器编译的时候size的大小是未知的,所以就会报出以上错误,可以将数组大小的变量定义为parameter即可
……
这与C++中其实是一样的

但是,我的情况中,ncv这个值没法定义为parameter。请问,我怎么才能实现在这个module里面,对ma进行数据共享?
PS:因为个人感觉程序其他部分对问题的描述作用不大,故没有贴出,请勿介意!

分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

712

帖子

4

主题

0

精华

大师

农村外出务工人员

F 币
607 元
贡献
311 点

新人勋章爱心勋章水王勋章元老勋章热心勋章

沙发
发表于 2014-10-10 08:09:46 | 只看该作者
使用可分配数组。

module 并不能解决动态分配问题。

评分

参与人数 1F 币 +2 贡献 +2 收起 理由
岸边的鱼 + 2 + 2 很给力!

查看全部评分

13

帖子

5

主题

0

精华

入门

F 币
87 元
贡献
50 点
板凳
 楼主| 发表于 2014-10-10 09:31:52 | 只看该作者
谢谢,我明白你的意思了!

136

帖子

3

主题

0

精华

版主

F 币
1964 元
贡献
1677 点

帅哥勋章管理勋章爱心勋章新人勋章热心勋章元老勋章

地板
发表于 2014-10-10 09:44:45 | 只看该作者
编译毫无问题啊~
[Fortran] 纯文本查看 复制代码
   MODULE module_defi_array
    
    Integer,Parameter   :: ncv=2

    End MODULE module_defi_array
!*****************************************************************************!
    MODULE module_slvr
    USE module_defi_array, only : ncv
    IMPLICIT NONE
    
    REAL(kind=8), DIMENSION(2,2,ncv) :: ma
    
    CONTAINS
    End MODULE module_slvr
!*****************************************************************************!
    Program www_fcode_cn
    Use module_slvr 
    Implicit None
    
    End Program www_fcode_cn

13

帖子

5

主题

0

精华

入门

F 币
87 元
贡献
50 点
5#
 楼主| 发表于 2014-10-10 09:54:02 | 只看该作者
aliouying 发表于 2014-10-10 09:44
编译毫无问题啊~
[mw_shl_code=fortran,true]   MODULE module_defi_array
   

非常感谢你这么热情地解答。
你这个就是演示的是解决这个问题的一个思路:将ncv设为一个parameter。
但正如我在问题中描述,我的情况是:这个ncv的取值是后面输入的,并不知道大小是多少。
谢谢

13

帖子

5

主题

0

精华

入门

F 币
87 元
贡献
50 点
6#
 楼主| 发表于 2014-10-10 10:08:26 | 只看该作者
aliouying 发表于 2014-10-10 09:44
编译毫无问题啊~
[Fortran] 纯文本查看 复制代码
   MODULE module_defi_array
    
[/quote]

[mw_shl_code=fortran,true]   MODULE module_defi_array
    
    Integer   :: ncv=2 !此处没有声明为有名常数

    End MODULE module_defi_array
!*****************************************************************************!
    MODULE module_slvr
    USE module_defi_array, only : ncv
    IMPLICIT NONE
    
    REAL(kind=8), DIMENSION(2,2,ncv) :: ma
    
    CONTAINS
    End MODULE module_slvr
!*****************************************************************************!
    Program www_fcode_cn
    Use module_slvr 
    Implicit None
    
    End Program www_fcode_cn

这样就是有问题的

1958

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1341 元
贡献
565 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

7#
发表于 2014-10-10 11:18:30 | 只看该作者
如沙发所言

136

帖子

3

主题

0

精华

版主

F 币
1964 元
贡献
1677 点

帅哥勋章管理勋章爱心勋章新人勋章热心勋章元老勋章

8#
发表于 2014-10-10 17:10:23 | 只看该作者
顶楼上
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

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

GMT+8, 2024-4-25 10:22

Powered by Tencent X3.4

© 2013-2024 Tencent

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