加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

011.golang 方法 method

发布时间:2020-12-16 19:18:21 所属栏目:大数据 来源:网络整理
导读:方法method Go 中虽没有class,但依旧有method 通过显示说明receiver来实现与某个类型的组合 只能为同一个包中的类型定义方法 Receiver 可以是类型的值或者指针 不存在方法重载 可以使用值或指针来调用方法,编译器会自动完成转换 从某种意义上来说,方法是

方法method

  • Go 中虽没有class,但依旧有method
  • 通过显示说明receiver来实现与某个类型的组合
  • 只能为同一个包中的类型定义方法
  • Receiver 可以是类型的值或者指针
  • 不存在方法重载
  • 可以使用值或指针来调用方法,编译器会自动完成转换
  • 从某种意义上来说,方法是函数的语法糖,因为receiver其实就是
  • 方法所接收的第1个参数(Method Value vs. Method Expression)
  • 如果外部结构和嵌入结构存在同名方法,则优先调用外部结构的方法
  • 类型别名不会拥有底层类型所附带的方法
  • 方法可以调用结构中的非公开字段

package main

import (
    "fmt"
)

type A struct {
    Name string
}

type B struct {
    Name string
}

func main() {
    //Receiver 可以是类型的值或者指针
    a := A{}
    a.Print()
    fmt.Println(a.Name) //打印为修改后的值

    b := B{}
    b.Print()
    fmt.Println(b.Name) //打印为空
}

//引用类型,指针的拷贝
func (a *A) Print() {
    a.Name = "AA"
    fmt.Println("A...")
}

//值类型,值得拷贝
func (b B) Print() {
    b.Name = "BB"
    fmt.Println("B...")
}

package main

import (
    "fmt"
)

type TTT int

func main() {
    //类型别名不会拥有底层类型所附带的方法
    var a TTT
    fmt.Println(a)
    a.Print()        //Method Value
    (*TTT).Print(&a) //Method Expression
}

func (a *TTT) Print() {
    fmt.Println("TTT",a)
}

package main

import (
    "fmt"
)

type A struct {
    name string //同一个包来讲,私有的也是可见的
}

func main() {
    //方法可以调用结构中的非公开字段
    a := A{}
    a.Print()
    fmt.Println(a.name)
}

func (a *A) Print() {
    a.name = "123"
    fmt.Println(a)
}

package main

import (
    "fmt"
)

type A int

func (a *A) Increase(num int) {
    *a += A(num)
}

func main() {
    //声明一个底层类型为int的类型,并实现调用某个方法就递增100
    var a A
    a.Increase(100)
    fmt.Println(a)
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读