修改了一些语句

This commit is contained in:
astaxie
2012-09-03 13:03:36 +08:00
parent e2f10b4038
commit e9c92a9a70
2 changed files with 16 additions and 15 deletions

18
2.6.md
View File

@@ -88,9 +88,9 @@ interface类型定义了一组方法如果某个对象实现了某个接口
最后任意的类型都实现了空interface(我们这样定义interface{})也就是包含0个method的interface。
###interface值
那么interface里面到底能存什么值呢如果我们定义了一个interface的变量那么这个变量里面可以存实现这个interface的任意类型。例如上面例子中我们定义了一个Men interface类型的变量m那么m里面可以存Human、Student或者Employee值。
那么interface里面到底能存什么值呢如果我们定义了一个interface的变量那么这个变量里面可以存实现这个interface的任意类型的对象。例如上面例子中我们定义了一个Men interface类型的变量m那么m里面可以存Human、Student或者Employee值。
那么既然m能够这三种类型的数值,那么我们可以定义一个包含men元素的slice样这个slice里面可以包含各种组合了这个和我们传统意义上面的slice有所不同。
因为m能够持有这三种类型的对象,所以我们可以定义一个Men类型元素的slice这个slice可以被赋予实现了Men接口的任意结构的对象这个和我们传统意义上面的slice有所不同。
让我们来看一下下面这个例子
@@ -170,10 +170,10 @@ interface类型定义了一组方法如果某个对象实现了某个接口
}
}
通过上面的代码你会发现interface其实他们是一组抽象方法,他不自己实现自己。他们就像:如果谁能实现我定义的方法,那么谁就拥有我
通过上面的代码你会发现interface是一组抽象方法的集合它必须由其他非interface类型实现而不能自我实现 go 通过interface实现了duck-typing:即"当看到一只鸟走起来像鸭子、游泳起来像鸭子、叫起来也像鸭子,那么这只鸟就可以被称为鸭子"
###空interface
空interface(interface{})不包含任何的method正因为如此所有的类型都实现了空interface。空interface对于描述他包含的method没有任何的用处但是对于我们存储任意类型的数值的时候相当有用,因为可以存储任意类型的数值。
空interface(interface{})不包含任何的method正因为如此所有的类型都实现了空interface。空interface对于描述起不到任何的作用(因为它不包含任何的method但是空interface在我们需要存储任意类型的数值的时候相当有用,因为可以存储任意类型的数值。它有点类似于C语言叫的void*类型。
// 定义a为空接口
var a interface{}
@@ -185,9 +185,9 @@ interface类型定义了一组方法如果某个对象实现了某个接口
一个函数把interface{}作为参数那么他可以接受任意类型的数值作为参数如果一个函数返回interface{},那么也就可以返回任意类型的数值。是不是很有用啊!
###interface函数参数
通过上面interface变量可以存储任意实现该interface值的类型数据,给我们编写函数(包括method)提供了一些额外的思考我们是不是可以通过定义interface参数让函数接受各种类型的参数。
interface变量可以持有任意实现该interface类型的对象,这给我们编写函数(包括method)提供了一些额外的思考我们是不是可以通过定义interface参数让函数接受各种类型的参数。
举个例子我们已经知道fmt.Println是我们常用的一个函数但是你是否注意到它可以接受任意类型的数据。其实我们打开fmt的源码他里面定义了一个interface Stringer
举个例子我们已经知道fmt.Println是我们常用的一个函数但是你是否注意到它可以接受任意类型的数据。打开fmt的源码文件,你会看到这样一个定义:
type Stringer interface {
String() string
@@ -215,7 +215,7 @@ interface类型定义了一组方法如果某个对象实现了某个接口
Bob := Human{"Bob", 39, "000-7777-XXX"}
fmt.Println("This Human is : ", Bob)
}
现在我们再回顾一下我们前面写的写的Box里面定义的Color的method string。其实我们也是实现了fmt.Stringer这个interface
现在我们再回顾一下前面的Box示例你会发现Color结构也定义了一个methodString。其实也是实现了fmt.Stringer这个interface,即如果需要自定义的类型能被fmt包输出你就必须实现interface Stringer这个接口
//实现同样的功能
fmt.Println("The biggest one is", boxes.BiggestsColor().String())
@@ -224,7 +224,7 @@ interface类型定义了一组方法如果某个对象实现了某个接口
###interface变量存储的类型
我们知道interface的变量里面可以存储任意类型的数值(该类型实现了interface)。那么我们怎么反向知道这个变量里面到底存储的是什么类型呢?目前常用的有两种方法:
我们知道interface的变量里面可以存储任意类型的数值(该类型实现了interface)。那么我们怎么反向知道这个变量里面实际保存了的是哪个类型的对象呢?目前常用的有两种方法:
- Comma-ok断言
@@ -356,7 +356,7 @@ Go里面真正吸引人的是他内置的逻辑语法就像我们在学习Str
###反射
Go语言实现了反射所谓反射就是动态运行时的状态。我们一般用到的包是reflect包。如何运用reflect包官方的这篇文章详细的讲解了reflect包的实现原理[laws of reflection](http://golang.org/doc/articles/laws_of_reflection.html)
下面我简要的讲解一下一般的使用reflect主要的实现过程分成三,首先我们要去反射的值都是一个类型的值,首先我们需要把它转化成interface(reflect.Type或者reflect.Value根据不同的情况调用不同的函数)。这两种获取方式如下:
下面我简要的讲解一下一般的使用,我们使用reflect大概的分成三首先我们要去反射是一个类型的值需要把它转化成interface(reflect.Type或者reflect.Value根据不同的情况调用不同的函数)。这两种获取方式如下:
t := reflect.TypeOf(i) //得到类型的元数据,通过t我们能获取类型定义里面的所有元素
v := reflect.ValueOf(i) //得到实际的值通过v我们获取存储在里面的值还可以去改变值