golang 调用dll 返回 如何获取返回的内容

本文介绍了一种通过Go语言调用DLL文件中导出函数的方法,并展示了如何处理返回的字符串数据。具体步骤包括加载DLL、创建过程实例、调用函数及解析返回的字符串。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目前中测试了返回字符串的内容,其它的结构体后再再测试


lib := syscall.NewLazyDLL("./lib/iTapTradeAPI_64.dll")
fmt.Println("dll:", lib.Name)
add := lib.NewProc("GetITapTradeAPIVersion")
fmt.Println("+++++++NewProc:", add, "+++++++")


ret, b, err := add.Call()
if err != nil {
   errGet := err.(syscall.Errno)
   if (errGet == 0) {
      fmt.Println("ret:", uintptr(ret))
      fmt.Println("b:", uintptr(b))

      p := (*byte)(unsafe.Pointer(ret))
      data := make([]byte, 0)

      for *p != 0 {
         data = append(data, *p)
         ret += unsafe.Sizeof(byte(0))
         p = (*byte)(unsafe.Pointer(ret))
      }
      ss := string(data)
      println(ss)

   } else {
      fmt.Println("错误:", err.Error())
   }
}

 

要在Go语言中调用MATLAB生成的DLL文件,你可以按照下面步骤进行操作: ### 步骤一:准备MATLAB DLL 1. **创建MATLAB函数**:首先,在MATLAB环境中编写你需要的功能,并测试其正确性。 2. **打包成共享库(.dll)**:利用MATLAB Compiler SDK将上述功能封装进一个动态链接库(DLL)内。这通常涉及到设置输入输出参数、选择目标平台(x64/x86),以及指定所需的依赖项等配置工作。完成后会得到`.h`头文件及相应的Windows下的.dll或Linux下的.so文件。 ### 步骤二:在Go项目里引入并加载该DLL 为了能够在Go程序中引用到这个外部库,可以借助cgo工具来完成这一任务。需要注意的是CGO_ENABLED环境变量应该设为1(默认值),并且保证系统安装了TDM-GCC MinGW-w64或者MSYS2这样的GCC编译套件用于处理C/C++代码片段. ```go /* #cgo CFLAGS: -I${SRCDIR}/path/to/matlab/include/ #cgo LDFLAGS: -L${SRCDIR}/path/to/matlab/lib/ -lYourMatlabLibNameWithoutDllExtension #include "mclmcrrt.h" #include "YourMatlabLibHeaderFile.h" // 这是你从matlab compiler sdk获得的.h 文件路径 */ import "C" func init() { // 初始化运行时支持(如果需要的话) } ``` ### 步骤三:调用MATLAB提供的APIs 一旦成功导入之后就可以像平常那样通过导出符号名直接访问那些由MATLAB自动生成的C风格接口啦! 例如假设有一个求解线性方程组Ax=b的相关接口,则可以在Go端如此编码: ```go package main // ... (上面提到过的 import 和其他必要的声明) func SolveLinearEquation(A *[]float64, B *[]float64) (*C.struct_MWArray_double_T , error){ var result C.struct_MWArray_double_T status := C.mlxDllFunctionCall(/*...*/) if int(status)!=0{ return nil,fmt.Errorf("Failed to solve linear equation") } return &result,nil } func main(){ /* 示例数据 */ A:=[]float64{9.,7.,5., 3.,5.,7., 2.,5.,8.} b := []float64{-8,-9,-4} res,err := SolveLinearEquation(&A,&b) if err!=nil{ log.Fatal(err.Error()) } fmt.Printf("Solution x = %v\n",res.Data) } ``` 请注意以上只是一个简化版的例子,实际应用时还需根据具体情况调整参数传递方式如矩阵维度说明等等;同时也要考虑内存管理的问题防止出现资源泄漏的情况发生。 此外,由于跨语言互操作性的复杂度较高,强烈建议详细阅读官方文档以便更好地理解和掌握其中涉及的知识点和技术细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值