如何跨子例程处理模块中的 Fortran 全局可分配变量

Her*_*rot 3 fortran module global-variables allocatable-array

我有以下模块,其中包含一个可分配变量,该变量在模块中定义,在子例程中分配,然后也在第一个子例程调用的第二个子例程中使用。在这种情况下,我是否必须将变量传递给第二个子例程并声明INTENT(inout)?或者因为它是一个全局变量,所以不需要作为参数传递?

MODULE test

  IMPLICIT NONE
  SAVE

  REAL,ALLOCATABLE,DIMENSION(:,:,:) :: total

CONTAINS

  !--- 1st subroutine
  SUBROUTINE my_subr1(n,m,z)
    IMPLICIT NONE
    INTEGER,INTENT(in) :: n,m,z
    ALLOCATE(total (n,m,z))
    total=.9
    CALL my_subr2(n)

  END SUBROUTINE my_subr1

  !-- 2nd subroutine
  SUBROUTINE my_subr2(n)
    IMPLICIT NONE
    INTEGER,INTENT(in) :: n

    total(n,:,:)=total(n-1,:,:)
  END SUBROUTINE my_subr2
END MODULE test
Run Code Online (Sandbox Code Playgroud)

Rod*_*ues 5

我是否必须将变量传递给第二个子例程并声明INTENT(inout)

不,你不知道。默认情况下,模块主体中声明的任何变量都具有该save属性。但是,您必须确保仅在执行第一个子例程之后调用第二个子例程,否则程序将失败,因为total尚未初始化。

total模块中声明的所有函数和子例程都可以通过主机关联访问。


顺便说一下,您应该在代码中解决一些问题,正如 @PierredeBuyl 在评论中提到的:

  • 默认保存模块体中声明的变量;你应该删除SAVE声明。
  • 模块中声明的过程继承IMPLICIT从模块范围继承指令,如果不更改它,则无需在子例程中重新声明它。
  • 您缺少 中参数的声明my_subr1