【发布时间】:2021-09-28 08:53:10
【问题描述】:
我有以下测试功能:
#include <stdlib.h>
#include <stdio.h>
void print_string(char *text);
void print_string(char *text) {
printf("---\n%s\n---\n", text);
}
以下模块使用 ISO c 绑定封装了 Fortran 子例程的调用:
module test_c_lib
use iso_c_binding
implicit none
contains
subroutine test(text)
use iso_c_binding
character,intent(in) :: text(:)
! Interface to C function
interface
subroutine c_print_string(t) bind(C, name="print_string")
import
character(kind=c_char) :: t(:)
end subroutine
end interface
! Call C function
print *,"AAAAA"
print *,text
print *,"AAAAA"
call c_print_string(text // C_NULL_CHAR)
end subroutine
end module
使用 ISO C BINDINGS 在 Fortran 中定义子例程的方法摘自此文档 link。我进一步封装了一点f2py不支持iso c绑定。
我通过makefile编译所有内容:
$ cat makefile
f_mod.so: f_mod.f90 c_lib.o
f2py -c f_mod.f90 c_lib.o -m f_mod
c_lib.o: c_lib.c
gcc -c -fpic c_lib.c -o c_lib.o
它编译但是:
- 我收到以下警告:
150 | call c_print_string(text // C_NULL_CHAR)
| 1
Warning: Character length mismatch (2/1) between actual argument and assumed-shape dummy argument 't' at (1) [-Wargument-mismatch]
- 通过
import fmod; f_mod.test_c_lib.test("Foo")调用时得到以下输出:
AAAAA
Foo
AAAAA
---
8v$
---
所以f2py 正在工作,但是当将text // C_NULL_CHAR 作为参数传递时,它似乎不起作用,因为我从 C 函数输出中得到了垃圾。
【问题讨论】:
-
在风格说明上,已经看到了您最近提出的一些问题:假设默认的内部类型参数是可互操作的参数可能是不好的做法。在这里,您假设默认的种类字符与可互操作的字符相同。您可能最好在整个过程中明确地使用可互操作的类型,或者明确地转换它们。
标签: fortran character f2py fortran-iso-c-binding