golang plugin小谈

栏目: Go · 发布时间: 7年前

内容简介:在1.8之前,如果我们想用第三方的库,只能获取到源码才可以,而不能使用编译后的代码,比如jar、dll、so文件。不过1.8中新加入了plugin包,我们可以通过这个包来实现调用、访问编译后方法和变量的功能,不过到目前版本(1.11.1)为止还不支持windows(几年没碰过这超恶心的os了,真嗨森。。。)。plugin 是一个包含可导出(首字母大写)函数和变量的main包。当一个plugin首次被打开的时候,是在所有包中的init方法已经调用完成之后,main方法执行之前。一个plugin只会被初始化一

在1.8之前,如果我们想用第三方的库,只能获取到源码才可以,而不能使用编译后的代码,比如jar、dll、so文件。不过1.8中新加入了plugin包,我们可以通过这个包来实现调用、访问编译后方法和变量的功能,不过到目前版本(1.11.1)为止还不支持windows(几年没碰过这超恶心的os了,真嗨森。。。)。

plugin 是一个包含可导出(首字母大写)函数和变量的main包。当一个plugin首次被打开的时候,是在所有包中的init方法已经调用完成之后,main方法执行之前。一个plugin只会被初始化一次,并且不会被关闭。plugin的操作都是协程安全的。

下面我们将会举个例子说明plugin包如何使用(类型转换,函数传参调用,修改变量的值)。plugin.go:

package main

import "fmt"

func Say(str string) string{
    return fmt.Sprintf("Hello, my name is: %s, addr is: %s\n",str,Addr)
}

var Addr = "default home address"

编译plugin需要使用-buildmode=plugin参数,编译后是一个.so文件:

go build --buildmode=plugin plugin.go

看一下caller.go:

package main

import (
    "fmt"
    "os"
    "plugin"
)

func main() {

    p, err := plugin.Open("plugin.so")
    if err != nil {
        panic(err)
    }
    sb, err := p.Lookup("Say")
    if err != nil {
        panic(err)
    }
    sbs := sb.(func(string) string)

    if len(os.Args) > 2 {

        str, err := p.Lookup("Addr")
        if err != nil {
            panic(err)
        }
        *str.(*string) = os.Args[2]
    }

    fmt.Println(sbs(os.Args[1]))
}

如果运行main的时候,有一个参数,则将参数传递给plugin中的Say方法(调用plugin函数);如果有两个或以上的参数,则第二个参数将会替换掉plugin中的Addr变量的值(修改plugin变量)。例如:

go run caller.go jingege
#Hello, my name is: jingege, addr is: default home address

go run caller.go jingege chengdu
#Hello, my name is: jingege, addr is: chengdu

注意

  • 1、plugin必须是在main包下,即 package mian
  • 2、编译plugin的时候,必须使用--buildmode=plugin参数
  • 3、Lookup只能查找可导出的成员(方法,变量等),并且返回参数为指针,需要转换成对应的类型才能使用

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS 3实战

CSS 3实战

成林 / 机械工业出版社 / 2011-5 / 69.00元

全书一共分为9章,首先从宏观上介绍了CSS 3技术的最新发展现状、新特性,以及现有的主流浏览器对这些新特性的支持情况;然后详细讲解了CSS 3的选择器、文本特性、颜色特性、弹性布局、边框和背景特性、盒模型、UI设计、多列布局、圆角和阴影、渐变、变形、转换、动画、投影、开放字体、设备类型、语音样式等重要的理论知识,这部分内容是本书的基础和核心。不仅每个知识点都配有丰富的、精心设计的实战案例,而且详细......一起来看看 《CSS 3实战》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

在线进制转换器
在线进制转换器

各进制数互转换器

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具