Fortran调用C++函数写法

Fortran Interface:

interface

logical function NodeData_Export(NodeNum,Node_X,Node_Y,Node_Z,Node_JN,Node_JS) bind(c,name='CUDAMallocNodeData_Export')
            use data_def
            integer, value:: NodeNum
            real(gk):: Node_X(NodeNum)
            real(gk):: Node_Y(NodeNum)
            real(gk):: Node_Z(NodeNum)
            integer :: Node_JN(NodeNum*6)
            integer :: Node_JS(NodeNum*3)
        end function

end interface

C++函数声明与实现:

extern "C" bool __declspec(dllexport)  NodeData_Export(const int NodeNum, float Node_X[], float Node_Y[], float Node_Z[], int Node_JN[], int Node_JS[]);

bool NodeData_Export(const int NodeNum, float Node_X[], float Node_Y[], float Node_Z[], int Node_JN[], int Node_JS[])
{
……
}

Fortran 调用:(Fortran调用的函数要添加interface的module)

DO I = 1,NJ
        Node_X(I) = NOD(I)%X
        Node_Y(I) = NOD(I)%Y
        Node_Z(I) = NOD(I)%Z
        Node_JN((I-1)*6 + 1:I*6) = NOD(I)%JN(1:6)
        Node_JS((I-1)*3 + 1:I*3) = NOD(I)%JS(4:6)
    END DO
    ERR = NodeData_Export(NJ,Node_X,Node_Y,Node_Z,Node_JN,Node_JS) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值