区块链技术语言(二十四):Go语言面向对象:匿名组合

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

内容简介:继承也是面向对象的三大基本特性之一。通过继承创建的新类称为“子类”或“派生类”,被继承的类称为“基类”、“父类”或“超类”。通过继承,不仅可以让某个类型的对象拥有属于自己的数据结构和操作,还会自动拥有父类的数据结构和操作。这使得现有的类在无需重新编写原来类的情况下对这些功能进行了扩展,很好地解决了代码的重用问题。继承机制的魅力和强大在于它允许程序员利用已经存在的类,并且可以以某种方式扩展这个类,而且对其他继承了这个父类属性和方法的对象没有影响。

继承也是面向对象的三大基本特性之一。

通过继承创建的新类称为“子类”或“派生类”,被继承的类称为“基类”、“父类”或“超类”。通过继承,不仅可以让某个类型的对象拥有属于自己的数据结构和操作,还会自动拥有父类的数据结构和操作。这使得现有的类在无需重新编写原来类的情况下对这些功能进行了扩展,很好地解决了代码的重用问题。

继承机制的魅力和强大在于它允许 程序员 利用已经存在的类,并且可以以某种方式扩展这个类,而且对其他继承了这个父类属性和方法的对象没有影响。

Go 语言没有继承这个概念,它通过匿名组合间接实现了继承的特性。

1

匿名组合实现的属性继承

1.1 匿名字段

在结构体那一章节介绍过Go语言的匿名字段:即只有类型、没有字段名的字段。虽然匿名字段没有名称,但本质上是以类型名为名称的字段。所有内置类型和自定义类型都可以作为匿名字段。

1.2 匿名字段构成的匿名组合

如果结构体中的匿名字段是结构体类型,那么这个结构体所拥有的全部字段都被隐式地引入了当前定义的这个结构体。这种结构体内部嵌套结构体匿名字段的组合被称作匿名组合。而结构体匿名字段中的成员可以通过外部结构体直接访问。

区块链技术语言(二十四):Go语言面向对象:匿名组合

1.3 同名字段构成的匿名组合

外部结构体的成员变量名和嵌入的结构体匿名字段中的成员变量名相同,则此外部结构体成员被称作同名字段。同名字段可以通过外部结构体直接访问,但是匿名字段中与同名字段同名的成员变量的访问需要显式调用,其他成员变量可以通过外部结构体直接访问。

区块链技术语言(二十四):Go语言面向对象:匿名组合

1.4 匿名组合和非匿名组合的区别

和匿名组合相比,非匿名组合有两点不同:

第一,内部的嵌入字段是有变量名的,调用该字段的内部成员需要显式调用;

第二,嵌入字段所拥有的全部字段并没有被隐式地引入当前定义的这个结构体,也就是没有实现继承。

区块链技术语言(二十四):Go语言面向对象:匿名组合

1.5 其他匿名字段

匿名字段不仅可以是结构体类型,还可以是其他任意的内置类型和自定义类型,甚至可以是结构体的指针类型。

1.5.1 非结构体类型

非结构体类型包括:所有的内置类型和自定义类型。

区块链技术语言(二十四):Go语言面向对象:匿名组合

1.5.2 结构体指针类型

匿名字段不仅可以是结构体类型,也可以是结构体指针类型。

区块链技术语言(二十四):Go语言面向对象:匿名组合

2

匿名组合的方法继承与重写

2.1 方法的继承

如果嵌套在结构体内部的匿名字段已经实现了一个方法,那么外部结构体就“继承”了这个方法。外部结构体也可以实现其他方法。

区块链技术语言(二十四):Go语言面向对象:匿名组合

2.2 方法的重写

如果嵌套在结构体内部的是匿名字段,内部结构体实现了方法。外部结构体对此方法进行了修改,这就叫做方法的重写。可以通过外部结构体直接访问重写后的方法,但是匿名字段的方法需要显式调用。

区块链技术语言(二十四):Go语言面向对象:匿名组合

原文链接:区块链技术语言(二十四):Go语言面向对象—匿名组合

参考资料

[1] 谭浩强.C++面向对象程序设计[M]. 清华大学出版社,2006

[2] 陈维兴,陈昕.C++面向对象程序设计[M]. 人民邮电出版社,2010

本文完,获取更多资讯,敬请关注区块链工程师。

区块链技术语言(二十四):Go语言面向对象:匿名组合

来源:链块学院

本文由布洛克专栏作者发布,代表作者观点,版权归作者所有,不代表布洛克科技观点

——TheEnd——

关注“布洛克科技”

区块链技术语言(二十四):Go语言面向对象:匿名组合


以上所述就是小编给大家介绍的《区块链技术语言(二十四):Go语言面向对象:匿名组合》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

Spark SQL内核剖析

Spark SQL内核剖析

朱锋、张韶全、黄明 / 电子工业出版社 / 2018-8 / 69.00元

Spark SQL 是 Spark 技术体系中较有影响力的应用(Killer application),也是 SQL-on-Hadoop 解决方案 中举足轻重的产品。《Spark SQL内核剖析》由 11 章构成,从源码层面深入介绍 Spark SQL 内部实现机制,以及在实际业务场 景中的开发实践,其中包括 SQL 编译实现、逻辑计划的生成与优化、物理计划的生成与优化、Aggregation 算......一起来看看 《Spark SQL内核剖析》 这本书的介绍吧!

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

各进制数互转换器

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具