Fortran Coder

查看: 8822|回复: 8
打印 上一主题 下一主题

[混编] C调用Fortran dll

[复制链接]

24

帖子

7

主题

0

精华

熟手

F 币
132 元
贡献
80 点
跳转到指定楼层
楼主
发表于 2017-1-3 11:48:58 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
谁有C调用Fortran dll的例题呀,最好可以运行,学习一下。自己尝试做了一个例题,出错了:  错误        1        error LNK2019: 无法解析的外部符号 "void __stdcall OUTPUT(int *,int *,int *)" (?OUTPUT@@YGXPAH00@Z),该符号在函数 _main 中被引用        D:\Personal\Desktop\for4c\main\main.obj        main


分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

58

帖子

9

主题

0

精华

熟手

F 币
256 元
贡献
163 点
沙发
发表于 2017-1-3 12:45:49 | 只看该作者

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1642 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

板凳
发表于 2017-1-3 13:06:14 | 只看该作者
楼上的例子非常的古老,建议用新的语法 ISO_C_Binding 实现混编。
本论坛有很多例子:
http://bbs.fcode.cn/forum.php?mo ... ypeid&typeid=16

24

帖子

7

主题

0

精华

熟手

F 币
132 元
贡献
80 点
地板
 楼主| 发表于 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 (16.94 KB, 下载次数: 334)

tupian1.jpg

tupian2.png (20.1 KB, 下载次数: 332)

tupian2.png

24

帖子

7

主题

0

精华

熟手

F 币
132 元
贡献
80 点
5#
 楼主| 发表于 2017-1-3 19:52:20 | 只看该作者
zhuhuanlai 发表于 2017-1-3 12:45
http://www.3lian.com/edu/2012/04-14/25509.html
有比较详细的例子

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

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

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

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

24

帖子

7

主题

0

精华

熟手

F 币
132 元
贡献
80 点
7#
 楼主| 发表于 2017-1-3 20:34:16 | 只看该作者
vvt 发表于 2017-1-3 20:09
不需要额外设置,在这个例子里。你需要把 C 语言编译出来的 obj 放入工程,才能链接。

并且这个例子是 for ...

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


图片1.png (14.42 KB, 下载次数: 328)

图片1.png

图片2.png (31.82 KB, 下载次数: 321)

图片2.png

图片3.png (11.54 KB, 下载次数: 333)

图片3.png

图片4.png (30.58 KB, 下载次数: 354)

图片4.png

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
8#
发表于 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);
}

24

帖子

7

主题

0

精华

熟手

F 币
132 元
贡献
80 点
9#
 楼主| 发表于 2017-1-4 09:23:56 | 只看该作者
好的,谢谢啦
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-12-26 16:47

Powered by Tencent X3.4

© 2013-2024 Tencent

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