开启辅助访问 切换到窄版
搜索

Fortran Coder

 找回密码
 极速注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

[复制链接]

C调用Fortran dll

[混编]
dongtian99 发表于 2017-1-3 11:48:58 查看229 回复8 阅读模式
谁有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
fcode 发表于 2017-1-3 13:06:14
楼上的例子非常的古老,建议用新的语法 ISO_C_Binding 实现混编。
本论坛有很多例子:
http://bbs.fcode.cn/forum.php?mo ... ypeid&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


tupian1.jpg
tupian2.png
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 ...

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


图片1.png
图片2.png
图片3.png
图片4.png
vvt 发表于 2017-1-3 21:06:51
[Fortran] 纯文本查看 复制代码
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)
[C] 纯文本查看 复制代码
#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
好的,谢谢啦
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则 长代码粘贴

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表