我正在尝试将类型绑定过程作为参数传递给另一个子例程。我想知道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
Fortran可以做到这一点吗?当我尝试使用ifort编译此代码时出现编译器错误。
答案 0 :(得分:6)
test_obj%add_integers_up不是一个过程 - 它恰好是一个名为add_integers_up的过程的绑定。您不能将绑定作为实际参数传递。
如果要传递与绑定关联的特定过程,请传递该过程!可以想像:
call print_result_of_subroutine(i4, add_integers_up)
但正如其他海报所述,在您的示例代码中,该过程的接口与print_result_of_subroutine中相应伪参数的接口不匹配。
如果test_obj%add_integers_up引用了一个关联的过程指针组件(并且该组件的接口与print_result_of_subroutine所期望的那个匹配)那么事情就像你期待的那样工作。
请注意,Fortran 90不支持类型绑定过程(或过程指针组件) - 您的代码非常需要Fortran 2003。
答案 1 :(得分:3)
你没有告诉我们你得到的确切错误信息,我自己也没试过你的例子,但我很确定问题是过程伪参数的界面与界面不对应传递给它的实际参数。
更明确地,random_subroutine
被声明为接受两个参数,而test_obj%add_integers_up
接受三个参数;即使其中一个作为传递对象伪参数,它仍然作为该过程的接口的一部分。