dongtian99 发表于 2017-1-3 11:48:58

C调用Fortran dll

谁有C调用Fortran dll的例题呀,最好可以运行,学习一下。自己尝试做了一个例题,出错了:错误        1        error LNK2019: 无法解析的外部符号 "void __stdcall OUTPUT(int *,int *,int *)" (?OUTPUT@@YGXPAH00@Z),该符号在函数 _main 中被引用        D:\Personal\Desktop\for4c\main\main.obj        main


zhuhuanlai 发表于 2017-1-3 12:45:49

http://www.3lian.com/edu/2012/04-14/25509.html
有比较详细的例子

fcode 发表于 2017-1-3 13:06:14

楼上的例子非常的古老,建议用新的语法 ISO_C_Binding 实现混编。
本论坛有很多例子:
http://bbs.fcode.cn/forum.php?mod=forumdisplay&fid=38&filter=typeid&typeid=16

dongtian99 发表于 2017-1-3 19:29:14

本帖最后由 dongtian99 于 2017-1-3 19:31 编辑

fcode 发表于 2017-1-3 13:06
楼上的例子非常的古老,建议用新的语法 ISO_C_Binding 实现混编。
本论坛有很多例子:
http://bbs.fcode.cn ...
您好,使用ISO_C_Binding,是不是还得设置一下呀?我用的VS2010 Fortran2011,试了一下论坛中的小程序,结果出错
Program voi0d
use ISO_C_BINDING
implicit none
external :: ss
interface
    subroutine print_a(s,a) bind(C,name='print_a_')
      import
      type(C_FUNPTR) , value :: s
      type(C_PTR) , value :: a
    end subroutine print_a
end interface
integer , target :: a = 256
call print_a( c_funloc(ss) , c_loc(a) )
print * , a
End Program voi0d
!************************************
    !需要传递的子程序如下:
!************************************
   subroutine ss(a) Bind( c )
    implicit none
    integer a
    a = a + 1
    print *,'a=',a
   end subroutine ss
D:\Personal\Desktop\tupian1
D:\Personal\Desktop\tupian2


dongtian99 发表于 2017-1-3 19:52:20

zhuhuanlai 发表于 2017-1-3 12:45
http://www.3lian.com/edu/2012/04-14/25509.html
有比较详细的例子

可能版本问题吧 我用的VS2010 fortran2011一运行出现了好多错误呀

vvt 发表于 2017-1-3 20:09:22

不需要额外设置,在这个例子里。你需要把 C 语言编译出来的 obj 放入工程,才能链接。

并且这个例子是 fortran (program main)调用 c 语言(print_a),然后c语言又调用fortran( subroutine ss)

dongtian99 发表于 2017-1-3 20:34:16

vvt 发表于 2017-1-3 20:09
不需要额外设置,在这个例子里。你需要把 C 语言编译出来的 obj 放入工程,才能链接。

并且这个例子是 for ...

还是有问题呀,刚接触这个,您能帮我看一下吗


vvt 发表于 2017-1-3 21:06:51

Program void
use ISO_C_BINDING
implicit none
interface
    subroutine print_a(s,a) bind(C,name='print_a_')
      import
      type(C_FUNPTR) , value :: s
      type(C_PTR) , value :: a
    end subroutine print_a
    subroutine ss(a) Bind( c , Name = "ss_" )
    implicit none
    integer a
   end subroutine ss
end interface
integer , target :: a = 256
call print_a( c_funloc(ss) , c_loc(a) )
print * , a
end program void
!************************************
    !需要传递的子程序如下:
!************************************
   subroutine ss(a) Bind( c , Name = "ss_" )
    implicit none
    integer a
    a = a + 1
    print *,'a=',a
   end subroutine ss

c语言代码(请把 C 语言代码的扩展名改为 .c 而不是 .cpp)
#include <stdio.h>
extern void ss_(int a);//我自己写的传递进来的ss子程序
void print_a_(void* t, int a){
//int b=(int)t;
ss_(a);//调用传递进来的子程序
//printf("ct_=%p\n",t);
printf("ca=%d\n", a);
}

dongtian99 发表于 2017-1-4 09:23:56

好的,谢谢啦
页: [1]
查看完整版本: C调用Fortran dll