GO 语言方法

方法的声明和普通函数的声明类似,只是在函数名称前面多了一个参数,这个参数把这个方法绑定到这个参数对应的类型上。
#####和函数关系
方法是特殊的函数,定义在某一特定的类型上,通过类型的实例来进行调用,这个实例被叫接收者(receiver)。
函数将变量作为参数:Function1(recv)
方法在变量上被调用:recv.Method1()
接收者必须有一个显式的名字,这个名字必须在方法中被使用。
receiver_type 叫做 (接收者)基本类型,这个类型必须在和方法同样的包中被声明。

在 Go 中,(接收者)类型关联的方法不写在类型结构里面,就像类那样;耦合更加宽松;类型和方法之间的关联由接收者来建立。
方法没有和数据定义(结构体)混在一起:它们是正交的类型;表示(数据)和行为(方法)是独立的。

注意: Go 语言不允许为简单的内置类型添加方法,所以下面定义的方法是非法的。

 
  1. package main
    
    import(
    "fmt"
    )
    
    
    func Add(a ,b int){ //函数合法
    fmt.Println(a+b)
    }
    
    func (a int) Add (b int){ //方法非法!不能是内置数据类型
    fmt.Println(a+b)
    }

这个时候我们需要用 Go 语言的type,来临时定义一个和int具有同样功能的类型。这个类型不能看成是int类型的别名,它们属于不同的类型,不能直接相互赋值。

修改后合法的方法定义如下:

 
  1. package main
    
    import(
    "fmt"
    )
    
    type myInt int
    
    func Add(a ,b int){ //函数
    fmt.Println(a+b)
    }
    
    func (a myInt) Add (b myInt){ //方法
    fmt.Println(a+b)
    }
    
    func main() {
    a, b := 3,4
    var aa,bb myInt = 3,4
    Add(a,b)
    aa.Add(bb)
    }

上面的表达式aa.Add称作选择子(selector),它为接收者aa选择合适的Add方法。

可以看成“类的”方法

Go 语言不像其它面相对象语言一样可以写个类,然后在类里面写一堆方法,但其实Go语言的方法很巧妙的实现了这种效果:我们只需要在普通函数前面加个接受者(receiver,写在函数名前面的括号里面),这样编译器就知道这个函数(方法)属于哪个struct了。例如:

 
  1. type A struct {
    Name string
    }
    
    func (a A)foo() { //接收者写在函数名前面的括号里面
    fmt.Println("foo")
    }
    
    func main() {
    a := A{}
    a.foo() //foo
    }

编程要求

本关的编程任务是在method.go文件中完成一个名为Sub_multi的方法,补全Begin-End之间的代码,要求自定义int类型数调用这个方法来返回两个自定义int类型数的差和积。

本关涉及的代码文件method.go的代码如下:

 
  1. package main
    
    import (
    "fmt"
    )
    
    type myInt int
    
    // 请在此自定义一个名为Sub_multi的方法,
    //要求自定义int类型数调用这个方法返回两个自定义int类型数的差和积。
    //重要提示:Go语言不允许为简单的内置类型添加方法
    /********* Begin *********/
    
    
    /********* End *********/
    
    func main() {
    var a, b myInt //自定义而非内置int类型
    fmt.Scanf("%d %d", &a, &b) //输入两个数
    c,d := a.Sub_multi(b)
    fmt.Println(c)
    fmt.Println(d)
    }

 答案
 

package main

import (
    "fmt"
)

type myInt int

    // 请在此自定义一个名为Sub_multi的方法,
	//要求自定义int类型数调用这个方法返回两个自定义int类型数的差和积。
	//重要提示:Go语言不允许为简单的内置类型添加方法
    /********* Begin *********/
    func (a myInt) Sub_multi(b myInt) (myInt, myInt) {
	return a - b, a * b
    }

    /********* End *********/

func main() {
    var a, b myInt    //自定义而非内置int类型
    fmt.Scanf("%d %d", &a, &b) //输入两个数
    c,d := a.Sub_multi(b)
    fmt.Println(c)
    fmt.Println(d)
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gradio是一个用于快速构建机器学习界面的Python库,它主要依赖于Flask和Werkzeug等库来搭建Web应用程序。如果您需要在Gradio调用Go语言方法,您需要先将Go方法编译成可执行文件,然后通过Gradio的接口来调用该可执行文件。 具体来说,您需要编写一个Python函数来启动Go可执行文件,并将其作为子进程运行。在这个Python函数,您可以使用Python的subprocess模块来启动Go可执行文件,并使用标准输入和输出流与该进程进行通信。然后,您可以将Gradio的输入传递给子进程,并将子进程的输出作为Gradio的输出返回。 下面是一个简单的示例代码,演示如何在Gradio调用Go可执行文件: ```python import subprocess def go_method(input): # 启动Go可执行文件 process = subprocess.Popen(['./path/to/go/executable'], stdin=subprocess.PIPE, stdout=subprocess.PIPE) # 将输入传递给子进程 process.stdin.write(input.encode()) process.stdin.flush() # 读取子进程的输出 output = process.stdout.readline().decode() # 关闭子进程 process.stdin.close() process.stdout.close() process.wait() # 返回输出 return output ``` 在这个示例,我们假设Go可执行文件是在当前目录的,您需要将`./path/to/go/executable`替换为实际的Go可执行文件路径。此外,这个示例只处理单行输入和输出,如果您的Go方法需要处理更复杂的输入和输出,请根据实际情况进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值