Go动态加载DLL动态库(非cgo)

本文介绍了如何在Go语言中动态加载系统库,如在Windows和Linux系统下寻找并加载动态库的原则,以及处理常见的模块找不到错误和依赖管理方法。

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

加载动态库

package main

import (
	"fmt"
	"runtime"

	"github.com/ebitengine/purego"
)

func getSystemLibrary() string {
	switch runtime.GOOS {
	case "darwin":
		return "/usr/lib/libSystem.B.dylib"
	case "linux":
		return "libc.so.6"
	default:
		panic(fmt.Errorf("GOOS=%s is not supported", runtime.GOOS))
	}
}

func main() {
	libc, err := purego.Dlopen(getSystemLibrary(), purego.RTLD_NOW|purego.RTLD_GLOBAL)
	if err != nil {
		panic(err)
	}
	var puts func(string)
	purego.RegisterLibFunc(&puts, libc, "puts")
	puts("Calling C from Go without Cgo!")
}

widows下的动态库查找原则

1. 应用程序加载时所在的目录。
2. 系统目录。使用kernel32.dll中的GetSystemDirectory获取。
3. 16位系统目录。
4. Windows目录。使用kernel32.dll中的GetWindowsDirectory获取。
5. 当前目录。使用kernel32.dll中的GetCurrentDirectory获取。
6. 系统环境变量PATH下的目录。

Linux 下的动态库查找原则

1. 默认搜索路径是/lib和/usr/lib
2. 在配置文件/etc/ld.so.conf中指定动态库搜索路径
3. 通过环境变量LD_LIBRARY_PATH指定动态库搜索路径。
4. 在编译目标代码时指定该程序的动态库搜索路径

常见错误

The specified module could not be found.
  1. 检查动态库所在路径是否存在并且有效
  2. 检查动态库依赖的其它动态库是不是存在缺失
    1. 依赖的动态库需要符合上述各个平台的查找路径原则
    2. windows下可以使用 os.Setenv 将动态库所依赖的其它动态库库目录添加到 PATH 环境变量中
    3. Linux 下也可以想windows一样,将依赖添加到 LD_LIBRARY_PATH环境变量中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值