• 接口是一个或多个方法签名名的集合,定义方式如下

    type Interface_Name interface { method_a() string method_b() int .... }

  • 只要某个类型拥有该接口的所有方法签名,就算实现该接口,无需显示声明实现了那个接口,这称为structural Typing

    package main
    import "fmt" type USB interface { //定义一个接口:方法的集合
    Name() string //Name方法,返回string
    Connect() //Connect方法
    } type PhoneConnecter struct { //定义一个结构
    name string //结构包含一个字段
    } func (pc PhoneConnecter) Name() string { //为结构定义一个方法,绑定接口
    return pc.name //该方法命名为接口内的字段
    } //返回结构体字段 func (pc PhoneConnecter) Connect() { //定义结构体另一个方法,与接口另一个方法绑定
    fmt.Println("Connect:", pc.name)
    }
    func main() {
    var a USB //定义一个变量为USB接口类型
    a = PhoneConnecter{"PhoneConnecter"} //实例化一个结构体,并赋值给变量(接口)USB
    a.Connect() //接口调用其Connect方法,也是结构方法
    } /*输出
    Connect: PhoneConnecter
    */
  • 接口可以作为匿名嵌入其它接口,或嵌入到结构中

    package main
    import "fmt" type USB interface { //定义一个接口:方法的集合
    Name() string //Name方法,返回string
    Connecter //嵌入Connecter接口,可以使用Connecter方法
    } type Connecter interface { //定义另一个接口 Connecter
    Connect() //包含一个接口方法:Connect
    }
    type PhoneConnecter struct { //定义一个结构
    name string //结构包含一个字段
    } func (pc PhoneConnecter) Name() string { //为结构定义一个方法,绑定接口
    return pc.name //该方法命名为接口内的字段
    } //返回结构体字段 func (pc PhoneConnecter) Connect() { //定义结构体另一个方法,与接口另一个方法绑定
    fmt.Println("Connect:", pc.name)
    }
    func main() {
    var a USB //定义一个变量为USB接口类型
    a = PhoneConnecter{"PhoneConnecter"} //实例化一个结构体,并赋值给变量(接口)USB
    a.Connect()
    Disconnect(a) //接口调用其Connect方法,也是结构方法
    }
  • 接口只是方法声明,没有实现调用,没有字段,只能通过绑定的类型方法访问

    package main
    import "fmt" type USB interface { //定义一个接口:方法的集合
    Name() string //Name方法,返回string
    Connecter //嵌入Connecter接口,可以使用Connecter方法
    } type Connecter interface { //定义另一个接口 Connecter
    Connect() //包含一个接口方法:Connect
    }
    type PhoneConnecter struct { //定义一个结构
    name string //结构包含一个字段
    } func (pc PhoneConnecter) Name() string { //为结构定义一个方法,绑定接口
    return pc.name //该方法命名为接口内的字段
    } //返回结构体字段 func (pc PhoneConnecter) Connect() { //定义结构体另一个方法,与接口另一个方法绑定
    fmt.Println("Connected:", pc.name)
    }
    func main() {
    var a USB //定义一个变量为USB接口类型
    a = PhoneConnecter{"htc M10"} //实例化一个结构体,并赋值给变量(接口)USB
    a.Connect()
    Disconnect(a) //接口调用其Connect方法,也是结构方法
    } func Disconnect(usb USB) {
    if pc, ok := usb.(PhoneConnecter); ok { //传入结构体,判断赋值是否成功
    fmt.Println("Disconnected:", pc.name)
    return
    }
    fmt.Println("UNknown device.")
    } /*输出
    Connect: htc M10
    Disconnect:htc M10
    */
  • go没有像其他语言继承,如python中的object表示元类,所有的类都继承自object类,go通过接口也类似实现了此定义,因为只要某个类型实现了某个接口的方法,我们就说此类实现了

    这个接口。 因为type empty interface{}---空接口没有任何方法,所以可以理解为所有的接口都实现了空接口的方法(继承)。

    package main
    import "fmt" type USB interface { //定义一个接口:方法的集合
    Name() string //Name方法,返回string
    Connecter //嵌入Connecter接口,可以使用Connecter方法
    } type Connecter interface { //定义另一个接口 Connecter
    Connect() //包含一个接口方法:Connect
    }
    type PhoneConnecter struct { //定义一个结构
    name string //结构包含一个字段
    } func (pc PhoneConnecter) Name() string { //为结构定义一个方法,绑定接口
    return pc.name //该方法命名为接口内的字段
    } //返回结构体字段 func (pc PhoneConnecter) Connect() { //定义结构体另一个方法,与接口另一个方法绑定
    fmt.Println("Connected:", pc.name)
    }
    func main() {
    var a USB //定义一个变量为USB接口类型
    a = PhoneConnecter{"htc M10"} //实例化一个结构体,并赋值给变量(接口)USB
    a.Connect()
    Disconnect(a) //接口调用其Connect方法,也是结构方法
    } # func Disconnect(usb interface{}) { //集成空接口,也可以实现
    # if pc, ok := usb.(PhoneConnecter); ok { //传入结构体,判断赋值是否成功
    # fmt.Println("Disconnected:", pc.name)
    # return
    # }
    # fmt.Println("UNknown device.")
    # } //通过switch判断接口类型:type...switch用法
    func Disconnect(usb interface{}) { //集成空接口,也可以实现
    switch v := usb.(type) {
    case PhoneConnecter:
    fmt.Println("Disconnected:", v.name)
    default:
    fmt.Println("UNknown device.")
    }
    } /*输出
    Connect: htc M10
    Disconnect:htc M10
    */
  • 接口间的转换: 只有子类接口可以转换为父类接口,因为父类接口包含了子类接口,子类接口可以调用父类接口一部分接口方法

  • 将对象赋值给接口是,会发生拷贝,而接口内部存储的是只想这个复制品的指针,也就意味着接口无法修改状态,也无法获取指针。

    ...
    func main() {
    pc := PhoneConnecter{"ipad book pro"} //实例化一个结构
    var a Connecter //定义a为接口变量
    a = Connecter(pc) //接口强制转换
    a.Connect() pc.name = "Iphone 7"
    a.Connect()
    ... /*输出
    pc.name= "ipad book pro" Connected: ipad book pro
    pc.name = "Iphone 7" Connected: ipad book pro
    */
    }
  • 只有当 接口存储的类型和对象都为nil时,接口才等于nil

    package main
    import "fmt" func main() {
    var a interface{}
    fmt.Println(a == nil) var p *int = nil
    a = p
    fmt.Println(a == nil)
    } /*输出
    true
    false
    */
  • 接口调用不会做Receiver的自动转换

  • 接口同样支持匿名字段的方法

  • 接口也可以实现类似OOP(面向对象编程)中的多态

  • 空接口可以作为任何类型数据的容器

golang基础--Interface接口的更多相关文章

  1. Golang 之 interface接口全面理解

    什么是interface 在面向对象编程中,可以这么说:“接口定义了对象的行为”, 那么具体的实现行为就取决于对象了. 在Go中,接口是一组方法签名(声明的是一组方法的集合).当一个类型为接口中的所有 ...

  2. Golang基础(8):go interface接口

    一:接口概要 接口是一种重要的类型,他是一组确定的方法集合. 一个接口变量可以存储任何实现了接口方法的具体值.一个重要的例子就是io.Reader和io.Writer type Reader inte ...

  3. Golang 入门系列(四)如何理解interface接口

    前面讲了很多Go 语言的基础知识,包括go环境的安装,go语言的语法等,感兴趣的朋友,可以先看看之前的文章.https://www.cnblogs.com/zhangweizhong/category ...

  4. golang面向对象和interface接口

    一. golang面向对象介绍 1.golang也支持面向对象编程,但是和传统的面向对象编程有区别,并不是纯粹的面向对象语言.2.golang没有类(class),golang语言的结合体(struc ...

  5. Java基础-面向接口(interface)编程

    Java基础-面向接口(interface)编程 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.接口的概念 接口是功能的集合,同样可看做是一种数据类型,是比抽象类更为抽象的“类 ...

  6. java基础13 接口(及关键字:interface、implements)

    接口 1.接口的定义格式 interface 接口名{ } interface :接口的关键字 implements:实现接口的关键字 2.接口的作用 1.程序的解耦.(低耦合)        2.定 ...

  7. Golang 基础之基础语法梳理 (三)

    大家好,今天将梳理出的 Go语言基础语法内容,分享给大家. 请多多指教,谢谢. 本次<Go语言基础语法内容>共分为三个章节,本文为第三章节 Golang 基础之基础语法梳理 (一) Gol ...

  8. Golang 基础之基础语法梳理 (一)

    大家好,今天将梳理出的 Go语言基础语法内容,分享给大家. 请多多指教,谢谢. 本次<Go语言基础语法内容>共分为三个章节,本文为第一章节 Golang 基础之基础语法梳理 (一) Gol ...

  9. Golang基础教程

    以下使用goland的IDE演示,包含总计的golang基础功能共20个章节 一.go语言结构: 二.go基础语法: 三.变量 四.常量 五.运算符 六.条件语句 七.循环 八.函数 九.变量作用域 ...

随机推荐

  1. Effective C++(4) 确定对象被使用前已先被初始化

    危害:读取未初始化的值会导致不明确甚至是半随机化的行为. 最佳处理办法:永远在使用对象之前先将它初始化:确保每一个构造函数都将对象的每一个成员初始化. 1 注意区分赋值和初始化: 从初始化的角度而言, ...

  2. webpack笔记一 起步

    webpack笔记一 起步 安装 对于大多数项目,我们建议本地安装(--save-dev).这可以在引入突破式变更(breaking change)版本时,更容易分别升级项目. 起步 初始化项目 mk ...

  3. 搭建企业级全网数据定时备份方案[cron + rsync]2

    1.1.1. rsync服务注意的问题 1.服务端 path=/backup/     -->带/ 2.客户端 rsync -avz /tmp/ rsync_backup@192.168.25. ...

  4. ZT 获得/修改共享互斥量属性:pthread_mutexattr_t

    bbs.chinaunix.net/thread-965755-1-1.html 5.   获得/修改共享互斥量属性:    #include<pthread.h>    intpthre ...

  5. 布隆过滤器(Bloom Filter)简要介绍

    一种节省空间的概率数据结构 布隆过滤器可以理解为一个不怎么精确的 set 结构,当你使用它的 contains 方法判断某个对象是否存在时,它可能会误判.但是布隆过滤器也不是特别不精确,只要参数设置的 ...

  6. 《梦断代码》读书笔记 part3

    第六章:搞掂设计方案 备份很重要. 必须从小项目开始,而且永远不要期望它变大,如果你这么想,就会做过度设计,把它想象得过于重要,更坏的情况是,你可能会被自己想象中的艰难工作所吓到.所以要从小 处起步, ...

  7. Spring+ehcache+redis两级缓存

    问题描述 场景:我们的应用系统是分布式集群的,可横向扩展的.应用中某个接口操作满足以下一个或多个条件: 1. 接口运行复杂代价大, 2. 接口返回数据量大, 3. 接口的数据基本不会更改, 4. 接口 ...

  8. jquery 中 attr 和 prop 的区别

    问题:在jQuery引入prop方法后,什么时候使用attr,什么时候使用prop,两者区别. 判断: 对于HTML元素本身所有的固有属性,在处理的时候,使用prop方法 对于HTML元素后来我们自己 ...

  9. Spring(五)之Bean定义继承和依赖注入

    一.Bean定义继承 bean定义可以包含许多配置信息,包括构造函数参数,属性值和特定于容器的信息,例如初始化方法,静态工厂方法名称等. 子bean定义从父定义继承配置数据.子定义可以根据需要覆盖某些 ...

  10. 定义一个类Point,代表一个点,public属性有x和y,方法有显示点坐标 show(),构造函数有两个参数分别给x,y赋值,在main方法中构造两个对象,再创建一方法(getMiddle)为取两个点构成线段的中点的坐标,参数为2个点对象,调用此方法后得到一个新的点,编写Application,显示该对象的坐标值。

    这个题让我更加明白了类创建对象的实质 代码中用到:1.对象作形参;2.对象作返回值 以下用代码具体分析: class Point1{ public double x; public double y; ...