回到简体

This commit is contained in:
chai2010
2016-02-15 11:06:34 +08:00
parent 9e878f9944
commit 2b37b23285
177 changed files with 2354 additions and 2354 deletions

View File

@@ -1,6 +1,6 @@
### 6.2.1. Nil也是一合法的接收器
### 6.2.1. Nil也是一合法的接收器
就像一些函數允許nil指針作爲參數一樣,方法理上也可以用nil指針作爲其接收器,尤其nil對於對象來説是合法的零值比如map或者slice。在下面的簡單int表的例子里nil代表的是空表:
就像一些函数允许nil指针作为参数一样,方法理上也可以用nil指针作为其接收器,尤其nil对于对象来说是合法的零值比如map或者slice。在下面的简单int表的例子里nil代表的是空表:
```go
// An IntList is a linked list of integers.
@@ -18,9 +18,9 @@ func (list *IntList) Sum() int {
}
```
你定義一個允許nil作接收器值的方法的類型時,在型前面的註釋中指出nil量代表的意是很有必要的,就像我上面例子里做的這樣
你定义一个允许nil作接收器值的方法的类型时,在型前面的注释中指出nil量代表的意是很有必要的,就像我上面例子里做的这样
下面是net/url包里Values型定的一部分。
下面是net/url包里Values型定的一部分。
<u><i>net/url</i></u>
```go
@@ -43,7 +43,7 @@ func (v Values) Add(key, value string) {
}
```
這個定義向外部暴露了一map的型的量,且提供了一些能夠簡單操作這個map的方法。這個map的value字段是一string的slice所以這個Values是一個多維map。客端使用這個變量的候可以使用map固有的一些操作(make切片m[key]等等),也可以使用里提供的操作方法,或者兩者併用,都是可以的:
这个定义向外部暴露了一map的型的量,且提供了一些能够简单操作这个map的方法。这个map的value字段是一string的slice所以这个Values是一个多维map。客端使用这个变量的候可以使用map固有的一些操作(make切片m[key]等等),也可以使用里提供的操作方法,或者两者并用,都是可以的:
<u><i>gopl.io/ch6/urlvalues</i></u>
```go
@@ -61,6 +61,6 @@ fmt.Println(m.Get("item")) // ""
m.Add("item", "3") // panic: assignment to entry in nil map
```
Get的最一次調用中nil接收器的行爲卽是一空map的行。我可以等價地將這個操作成Value(nil).Get("item"),但是如果你直接nil.Get("item")的話是無法通過編譯的,因nil的字面量編譯器無法判斷其準備類型。所以相比之下,最的那行m.Add的調用就會産生一panic爲他嚐試更新一空map。
Get的最一次用中nil接收器的行为即是一空map的行。我可以等价地将这个操作成Value(nil).Get("item"),但是如果你直接nil.Get("item")的话是无法通过编译的,因nil的字面量编译器无法判断其准备类型。所以相比之下,最的那行m.Add的用就会产生一panic为他尝试更新一空map。
url.Values是一map型,併且間接引用了其key/value因此url.Values.Add對這個map里的元素做任何的更新、除操作對調用方都是可的。實際上,就像在普通函中一樣,雖然可以通引用操作部值,但在方法想要改引用本身是不會影響原始值的,比如把他置nil或者讓這個引用指向了其它的象,調用方都不受影。(譯註:因爲傳入的是存儲了內存地址的量,你改變這個變量是影不了原始的量的想想C言,是差不多的)
url.Values是一map型,并且间接引用了其key/value因此url.Values.Add对这个map里的元素做任何的更新、除操作对调用方都是可的。实际上,就像在普通函中一样,虽然可以通引用操作部值,但在方法想要改引用本身是不会影响原始值的,比如把他置nil或者让这个引用指向了其它的象,用方都不受影。(译注:因为传入的是存储了内存地址的量,你改变这个变量是影不了原始的量的想想C言,是差不多的)