要解决包含不可与C语言互操作的派生类型的Fortran和C语言接口的问题,可以使用以下步骤:
module my_module
implicit none
type :: my_derived_type
integer :: my_integer
real :: my_real
character(len=20) :: my_string
end type my_derived_type
end module my_module
subroutine my_function(obj) bind(C)
use my_module
implicit none
type(my_derived_type), intent(in) :: obj
! 拆分派生类型的数据
integer(c_int), value :: my_integer = obj%my_integer
real(c_float), value :: my_real = obj%my_real
character(len=20, kind=c_char), dimension(20), target :: my_string = obj%my_string
! 调用C语言函数
call my_c_function(my_integer, my_real, my_string)
end subroutine my_function
#include
void my_c_function(int my_integer, float my_real, char my_string[20]) {
printf("my_integer = %d\n", my_integer);
printf("my_real = %f\n", my_real);
printf("my_string = %s\n", my_string);
}
program main
use my_module
implicit none
type(my_derived_type) :: my_object
! 设置派生类型的数据
my_object%my_integer = 10
my_object%my_real = 3.14
my_object%my_string = "Hello, World!"
! 调用Fortran函数来传递派生类型的对象给C函数
call my_function(my_object)
end program main
在以上示例中,Fortran代码定义了一个包含派生类型的模块,并定义了一个子程序来将派生类型的对象传递给C函数。C代码定义了一个函数来接收来自Fortran的派生类型的数据,并执行所需的操作。最后,Fortran程序调用了子程序来传递派生类型的对象给C函数。
上一篇:包含布局的数据绑定变量为空。
下一篇:包含不起作用但分割可以使用。