0

0

用 Go 编写 Ruby 扩展

碧海醫心

碧海醫心

发布时间:2025-10-06 13:29:34

|

1013人浏览过

|

来源于php中文网

原创

用 go 编写 ruby 扩展

本文介绍了如何使用 Go 语言编写 Ruby 扩展。利用 Go 1.5 及以上版本提供的构建共享库的功能,我们可以直接将 Go 函数暴露给 Ruby,无需编写额外的 C 语言胶水层。通过一个简单的加法函数示例,详细讲解了 Go 代码的编写、编译以及 Ruby 中调用 Go 函数的步骤,帮助开发者快速上手,利用 Go 的高性能和并发特性来增强 Ruby 应用的功能。

使用 Go 构建 Ruby 扩展

Go 1.5 版本之后,Go 提供了构建可以从 C 代码调用的共享库的支持,这使得使用 Go 编写 Ruby 扩展变得更加容易。 相比于之前的版本,现在无需编写 C 语言胶水层,并且可以使用 Go 运行时,这使得在 Ruby 扩展中使用 goroutine 和内存分配成为可能。

1. 编写 Go 代码

首先,我们需要编写 Go 代码,其中包含我们想要暴露给 Ruby 的函数。

package main

import "C"

//export GoAdd
func GoAdd(a, b C.int) C.int {
    return a + b
}

func main() {} // Required but ignored

代码解释:

  • package main: 声明包名为 main,这是构建共享库所必需的。
  • import "C": 导入 C 包,允许 Go 代码与 C 代码交互。
  • //export GoAdd: 这是一个特殊的注释,用于告诉 Go 编译器导出 GoAdd 函数。export 关键字后面的符号是函数导出的名称。
  • func GoAdd(a, b C.int) C.int: 定义了一个名为 GoAdd 的函数,它接受两个 C 语言的整数作为参数,并返回它们的和。 注意,参数和返回值的类型必须是 C 语言兼容的类型,例如 C.int。
  • func main() {}: main 函数是必需的,但是会被忽略。

2. 编译 Go 代码为共享库

使用以下命令将 Go 代码编译为共享库:

go build -buildmode=c-shared -o goFuncs.so goFuncs.go

命令解释:

  • go build: Go 编译命令。
  • -buildmode=c-shared: 指定构建模式为 c-shared,这会生成一个可以从 C 代码调用的共享库。
  • -o goFuncs.so: 指定输出文件的名称为 goFuncs.so。
  • goFuncs.go: Go 源代码文件。

3. 在 Ruby 中调用 Go 函数

火龙果写作
火龙果写作

用火龙果,轻松写作,通过校对、改写、扩展等功能实现高质量内容生产。

下载

接下来,我们需要编写 Ruby 代码来加载共享库并调用 Go 函数。

require 'ffi'

module GoFuncs
  extend FFI::Library
  ffi_lib './goFuncs.so'
  attach_function :GoAdd, [:int, :int], :int
end

puts GoFuncs.GoAdd(41, 1)

代码解释:

  • require 'ffi': 导入 ffi 库,它提供了在 Ruby 中调用 C 函数的功能。
  • module GoFuncs: 定义一个名为 GoFuncs 的模块,用于封装 Go 函数。
  • extend FFI::Library: 扩展 FFI::Library 模块,使其具有加载共享库和调用 C 函数的功能。
  • ffi_lib './goFuncs.so': 指定要加载的共享库的路径。
  • attach_function :GoAdd, [:int, :int], :int: 将 GoAdd 函数附加到 GoFuncs 模块。第一个参数是 Ruby 中使用的函数名称,第二个参数是参数类型列表,第三个参数是返回值类型。
  • puts GoFuncs.GoAdd(41, 1): 调用 GoAdd 函数,并将结果打印到控制台。

4. 运行 Ruby 脚本

运行 Ruby 脚本,将会输出 Go 函数的计算结果:

ruby goFromRuby.rb

输出结果:

42

注意事项:

  • 确保 Go 编译器版本在 1.5 及以上。
  • 在编译 Go 代码时,必须使用 -buildmode=c-shared 标志。
  • 在 Ruby 代码中,必须使用 ffi 库来加载共享库和调用 Go 函数。
  • Go 函数的参数和返回值类型必须是 C 语言兼容的类型。
  • //export 注释是必需的,用于告诉 Go 编译器导出函数。

总结:

通过以上步骤,我们成功地使用 Go 编写了一个 Ruby 扩展。 这种方法允许我们利用 Go 的高性能和并发特性来增强 Ruby 应用的功能。 随着 Go 语言的不断发展,我们可以期待更多使用 Go 编写 Ruby 扩展的场景。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

465

2023.11.27

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

537

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

194

2025.08.29

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

34

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

33

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

18

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go 教程
Go 教程

共32课时 | 3.7万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号