回到简体

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,12 +1,12 @@
## 7.13. 類型開關
## 7.13. 类型开关
接口被以兩種不同的方式使用。在第一方式中以io.Readerio.Writerfmt.Stringersort.Interfacehttp.Handler和error典型,一接口的方法表達了實現這個接口的具體類型間的相思性,但是藏了代表的細節和這些具體類型本身的操作。重點在於方法上,而不是具體的類型上。
接口被以两种不同的方式使用。在第一方式中以io.Readerio.Writerfmt.Stringersort.Interfacehttp.Handler和error典型,一接口的方法表达了实现这个接口的具体类型间的相思性,但是藏了代表的细节和这些具体类型本身的操作。重点在于方法上,而不是具体的类型上。
第二方式利用一接口值可以持有各種具體類型值的能力併且將這個接口認爲是這些類型的union合)。類型斷言用來動態地區别這些類型併且對每一種情況都不一。在這個方式中,重點在於具體的類型滿足這個接口,而不是在接口的方法(如果它確實有一些的併且沒有任何的信息藏。我們將以這種方式使用的接口描述discriminated unions可辨識聯合)。
第二方式利用一接口值可以持有各种具体类型值的能力并且将这个接口认为是这些类型的union合)。类型断言用来动态地区别这些类型并且对每一种情况都不一。在这个方式中,重点在于具体的类型满足这个接口,而不是在接口的方法(如果它确实有一些的并且没有任何的信息藏。我们将以这种方式使用的接口描述discriminated unions可辨识联合)。
如果你熟悉面向對象編程,你可能會將這兩種方式作是subtype polymorphism型多)和 ad hoc polymorphism參數多態),但是你不需要去記住這些術語。對於本章剩下的部分,我們將會呈現一些第二方式的例子。
如果你熟悉面向对象编程,你可能会将这两种方式作是subtype polymorphism型多)和 ad hoc polymorphism参数多态),但是你不需要去记住这些术语。对于本章剩下的部分,我们将会呈现一些第二方式的例子。
和其它那些言一Go語言査詢一個SQL數據庫的API會榦淨地將査詢中固定的部分和化的部分分。一個調用的例子可能看起來像這樣
和其它那些言一Go语言查询一个SQL数据库的API会干净地将查询中固定的部分和化的部分分。一个调用的例子可能看起来像这样
```go
import "database/sql"
@@ -19,7 +19,7 @@ func listTracks(db sql.DB, artist string, minYear, maxYear int) {
}
```
Exec方法使用SQL字面量替換在査詢字符串中的每'?'SQL字面量表示相應參數的值,它有可能是一個布爾值,一個數字,一字符串或者nil空值。用這種方式構造査詢可以助避免SQL入攻擊;這種攻擊就是手可以通利用輸入內容中不正的引文來控製査詢語句。在Exec函數內部,我可能找到像下面這樣的一個函數,它會將每一個參數值轉換成它的SQL字面量符
Exec方法使用SQL字面量替换在查询字符串中的每'?'SQL字面量表示相应参数的值,它有可能是一个布尔值,一个数字,一字符串或者nil空值。用这种方式构造查询可以助避免SQL入攻击;这种攻击就是手可以通利用输入内容中不正的引文来控制查询语句。在Exec函数内部,我可能找到像下面这样的一个函数,它会将每一个参数值转换成它的SQL字面量符
```go
func sqlQuote(x interface{}) string {
@@ -42,9 +42,9 @@ func sqlQuote(x interface{}) string {
}
```
switch句可以化if-else,如果這個if-else鏈對一連串值做相等測試。一相似的type switch類型開關)可以簡化類型斷言的if-else
switch句可以化if-else,如果这个if-else链对一连串值做相等测试。一相似的type switch类型开关)可以简化类型断言的if-else
在它最簡單的形式中,一個類型開關像普通的switch句一,它的運算對象是x.(type)-它使用了關鍵詞字面量type且每case有一到多個類型。一個類型開關基於這個接口值的動態類型使一多路分支有效。這個nil的case和if x == nil匹配併且這個default的case和如果其它case都不匹配的情匹配。一個對sqlQuote的類型開關可能會有這些case
在它最简单的形式中,一个类型开关像普通的switch句一,它的运算对象是x.(type)-它使用了关键词字面量type且每case有一到多个类型。一个类型开关基于这个接口值的动态类型使一多路分支有效。这个nil的case和if x == nil匹配并且这个default的case和如果其它case都不匹配的情匹配。一个对sqlQuote的类型开关可能会有这些case
```go
switch x.(type) {
@@ -56,17 +56,17 @@ switch x.(type) {
}
```
和(§1.8)中的普通switch句一,每一case會被順序的行考併且當一個匹配找到時這個case中的內容會被執行。當一個或多case型是接口case的序就會變得很重要,因可能會有兩個case同匹配的情。default case相其它case的位置是無所謂的。它不會允許落空生。
和(§1.8)中的普通switch句一,每一case会被顺序的行考并且当一个匹配找到时这个case中的内容会被执行。当一个或多case型是接口case的序就会变得很重要,因可能会有两个case同匹配的情。default case相其它case的位置是无所谓的。它不会允许落空生。
意到在原的函中,對於bool和string情況的邏輯需要通過類型斷言訪問提取的值。因爲這個做法很典型,類型開關語句有一個擴展的形式,它可以提取的值定到一在每case范圍內的新量。
意到在原的函中,对于bool和string情况的逻辑需要通过类型断言访问提取的值。因为这个做法很典型,类型开关语句有一个扩展的形式,它可以提取的值定到一在每case范围内的新量。
```go
switch x := x.(type) { /* ... */ }
```
里我們已經將新的量也命名x類型斷言一,重用量名是很常的。和一switch句相似地,一個類型開關隱式的建了一個語言塊,因此新量x的定義不會和外面中的x變量衝突。每一case也會隱式的建一個單獨的語言塊
里我们已经将新的量也命名x类型断言一,重用量名是很常的。和一switch句相似地,一个类型开关隐式的建了一个语言块,因此新量x的定义不会和外面中的x变量冲突。每一case也会隐式的建一个单独的语言块
使用類型開關的擴展形式來重寫sqlQuote函數會讓這個函數更加的清晰:
使用类型开关的扩展形式来重写sqlQuote函数会让这个函数更加的清晰:
```go
func sqlQuote(x interface{}) string {
@@ -88,6 +88,6 @@ func sqlQuote(x interface{}) string {
}
```
這個版本的函中,在每個單一類型的case部,量x和這個case的型相同。例如,量x在bool的case中是bool型和string的case中是string型。在所有其它的情中,量x是switch運算對象的型(接口);在這個例子中運算對象是一interface{}。當多個case需要相同的操作比如int和uint的情況,類型開關可以很容易的合併這些情
这个版本的函中,在每个单一类型的case部,量x和这个case的型相同。例如,量x在bool的case中是bool型和string的case中是string型。在所有其它的情中,量x是switch运算对象的型(接口);在这个例子中运算对象是一interface{}。当多个case需要相同的操作比如int和uint的情况,类型开关可以很容易的合并这些情
管sqlQuote接受一任意型的參數,但是這個函數隻會在它的參數匹配類型開關中的一case時運行到束;其它情的它panic出“unexpected type”消息。然x的型是interface{},但是我把它認爲是一intuintboolstring和nil值的discriminated union識别聯合)
管sqlQuote接受一任意型的参数,但是这个函数只会在它的参数匹配类型开关中的一case时运行到束;其它情的它panic出“unexpected type”消息。然x的型是interface{},但是我把它认为是一intuintboolstring和nil值的discriminated union识别联合)