Sub*_*iva 4 fortran function user-defined-types fortran2003
我试图将类型绑定过程作为参数传递给另一个子例程.我想知道Fortran中是否可行.这是一个代码片段,显示了我想要做的事情.
module type_definitions
type test_type
integer :: i1, i2,i3
contains
procedure :: add_integers_up
end type test_type
contains
subroutine add_integers_up(this,i4,ans)
class(test_type) :: this
integer :: i4,ans
ans = this%i1+this%i2+this%i3+i4
end subroutine add_integers_up
subroutine print_result_of_subroutine(i4,random_subroutine)
integer :: i4,ans
interface
subroutine random_subroutine(i1,i2)
integer:: i1,i2
end subroutine random_subroutine
end interface
call random_subroutine(i4,ans)
write(*,*) ans
end subroutine print_result_of_subroutine
end module type_definitions
program main
use type_definitions
implicit none
integer :: i1,i2,i3,i4
integer :: ans
type(test_type) :: test_obj
i1 =1; i2=2; i3=3
test_obj%i1 = i1
test_obj%i2 = i2
test_obj%i3 = i3
i4 = 4
call print_result_of_subroutine(i4,test_obj%add_integers_up)
end program main
Run Code Online (Sandbox Code Playgroud)
Fortran可以做到这一点吗?当我尝试使用ifort编译此代码时出现编译器错误.
test_obj%add_integers_up不是一个过程 - 它恰好是一个名为add_integers_up的过程的绑定.您不能将绑定作为实际参数传递.
如果要传递与绑定关联的特定过程,请传递该过程!可以想像:
call print_result_of_subroutine(i4, add_integers_up)
Run Code Online (Sandbox Code Playgroud)
但正如其他海报所指出的那样,在您的示例代码中,该过程的接口与print_result_of_subroutine中相应伪参数的接口不匹配.
如果test_obj%add_integers_up引用了一个关联的过程指针组件(并且该组件的接口与print_result_of_subroutine所期望的相匹配)那么事情会像你期望的那样工作.
请注意,Fortran 90不支持类型绑定过程(或过程指针组件) - 您的代码非常需要Fortran 2003.