当前位置:首页 > 文章列表 > Golang > Go问答 > 如何在Windows环境下使用bazel的rules_go生成.so文件

如何在Windows环境下使用bazel的rules_go生成.so文件

来源:stackoverflow 2024-02-14 21:03:26 0浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《如何在Windows环境下使用bazel的rules_go生成.so文件》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!

问题内容

我已经切换(或者正在切换)使用 bazel,尽管我是在 windows 上这样做的。 我有兴趣从 java 调用我的 go 代码,因此我从本教程开始。

我能够使用与他们的 github 示例相同的代码来完成这项工作,并且一切正常。我尝试将其适应我的 bazel 构建。如果我采用 go build -o awesome.so -buildmode=c-shared awesome.go 生成的 awesome.so 文件并将其作为资源包含到我的 java_library 中,我就可以使一切正常工作。

相关文件如下所示。

但是,理想情况下,我希望通过 bazel 生成所有内容,但尽管到目前为止我进行了所有尝试,我的 go_binary 规则始终输出 awesome.a (和 awesome.x)。如果我切换到使用 //go:awesome 作为 java:client_lib 的资源,我能够成功地将 awesome.a 输出视为资源,这表明让我的 go_binary 输出 awesome.so 是最后一部分谜题,但到目前为止我还没有找到正确的标志组合。

基本上我只是想让我的 go_binary 规则具有与运行 go build -o awesome.so --buildmode=c-shared awesome.go 相同的行为。

理论上,如果我需要另一个规则来弥补差距,我没问题,但由于我在 windows 上,并且 bash 到目前为止已经时好时坏,使用 genrule 作为中间体目前看起来不太有希望。 p>

请指教,谢谢!

工作空间

...

# bazelbuild/rules_go for golang support.
http_archive(
    name = "io_bazel_rules_go",
    sha256 = "b725e6497741d7fc2d55fcc29a276627d10e43fa5d0bb692692890ae30d98d00",
    urls = [
        "https://mirror.bazel.build/github.com/bazelbuild/rules_go/releases/download/v0.24.3/rules_go-v0.24.3.tar.gz",
        "https://github.com/bazelbuild/rules_go/releases/download/v0.24.3/rules_go-v0.24.3.tar.gz",
    ],
)

load("@io_bazel_rules_go//go:deps.bzl", "go_register_toolchains", "go_rules_dependencies")

go_rules_dependencies()

go_register_toolchains()
...

go/awesome.go 是从文章中复制的。

去/构建

load("@io_bazel_rules_go//go:def.bzl", "go_binary", "go_library")

package(default_visibility = ["//visibility:public"])

go_binary(
    name = "awesome",
    srcs = glob(["*.go"]),
    cgo = true,
    copts = [
        "-fpic",  # i tried adding this after some other reading about .a->.so
    ],
    gc_linkopts = [
        "-shared", # i think this is equivalent to the linkmode=c-shared below, but... 
    ],
    linkmode = "c-shared",
    static = "off",
)

# this one uses the pre-built awesome.so, and this works.
filegroup(
    name = "prebuilt_awesome_resource",
    srcs = ["awesome.so"],
)

java/client.java 是从文章中链接的 github 存储库复制的(对库的位置进行了轻微调整)。

java/构建

package(default_visibility = ["//visibility:public"])

java_import(
    name = "jna",
    jars = ["jna.jar"],
)

java_library(
    name = "client_lib",
    srcs = glob(["*.java"]),
    resources = [
        #        "//go:awesome",  # i'd rather use this one.
        "//go:prebuilt_awesome_resource",
    ],
    deps = [
        ":jna",
    ],
)

java_binary(
    name = "client",
    main_class = "client",
    runtime_deps = [
        ":client_lib",
    ],
)

而且,因为让 go 运行起来很重要:

%programdata%/basel.bazelrc

startup --output_user_root="C:/_bazel_out"
build --compiler=mingw-gcc

解决方案


好吧,我想我需要在耻辱立方里坐一会儿。

在我为编译器寻找的所有选项中,我错过了检查 go_binary 上的其他属性。具体来说,最明显的是 out。实际上对应于 go build 上的 -o 标志的那个

我将 out = "awesome.so" 添加到我的 go_binary 规则中,果然,一切正常。

好吧,这几个小时就被浪费了。感谢 jay 试图提供帮助,并抱歉提出了一个愚蠢的问题。

这可能无法准确回答您的问题,但我可以举一个在 macos 上从 c 程序调用 go 共享库的示例。希望这能让您顺利完成任务。

  • 对于 go_binary,您只需要 linkmode = "c-shared"。对于每个包含 cgo 代码或已导出定义的包,您还需要 cgo = true 。您不需要 -shared-fpicstatic = "off"
  • 导出的定义应标有 //export 注释。
  • 有一个隐式声明的目标,其后缀为 .c_hdrs,它为 go 库构建头文件。在下面的示例中,它是 :go_hello.c_hdrs。实际的头文件名为go_hello.h,与目标名称匹配。
  • 您需要使用 cc_import 规则包装生成的文件,以使其可用作 c/c++ 依赖项。 #2433 是一个简化该流程的开放问题,但最近才在 bazel 中实现。
  • 任何可以使用 cc_library 的东西都可以以相同的方式使用 cc_import 目标。所以你应该能够通过 jni 调用 go 函数,尽管我从未尝试过。

构建.bazel

load("@io_bazel_rules_go//go:def.bzl", "go_binary")

go_binary(
    name = "go_hello",
    srcs = ["hello.go"],
    cgo = true,
    linkmode = "c-shared",
)

cc_import(
    name = "c_hello",
    hdrs = [":go_hello.c_hdrs"],
    shared_library = ":go_hello",
)

cc_binary(
    name = "use",
    srcs = ["use.c"],
    deps = [":c_hello"],
)

你好。

package main

import "fmt"
import "c"

//export sayhello
func sayhello() {
    fmt.println("hello")
}

func main() {}

使用.c

#include "go_hello.h"

int main() {
  SayHello();
  return 0;
}

本篇关于《如何在Windows环境下使用bazel的rules_go生成.so文件》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
关于container_memory_working_set_bytes、process_resident_memory_bytes和total_rss之间的关联关于container_memory_working_set_bytes、process_resident_memory_bytes和total_rss之间的关联
上一篇
关于container_memory_working_set_bytes、process_resident_memory_bytes和total_rss之间的关联
使用递归的方式解组嵌套结构
下一篇
使用递归的方式解组嵌套结构
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    308次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    325次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    294次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    472次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    457次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码