回到简体

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 @@
## 7.12. 通過類型斷言詢問行爲
## 7.12. 通过类型断言询问行为
下面這段邏輯和net/http包中web服務器負責寫入HTTP字段(例如:"Content-type:text/html的部分相似。io.Writer接口型的量w代表HTTP響應;寫入它的字節最終被發送到某人的web瀏覽器上。
下面这段逻辑和net/http包中web服务器负责写入HTTP字段(例如:"Content-type:text/html的部分相似。io.Writer接口型的量w代表HTTP响应;写入它的字节最终被发送到某人的web浏览器上。
```go
func writeHeader(w io.Writer, contentType string) error {
@@ -14,11 +14,11 @@ func writeHeader(w io.Writer, contentType string) error {
}
```
Write方法需要入一byte切片而我希望入的值是一字符串,所以我需要使用[]byte(...)進行轉換。這個轉換分配內存併且做一個拷貝,但是這個拷貝在轉換後幾乎立就被丟棄掉。讓我們假裝這是一web服器的核心部分且我的性能分析表示這個內存分配使服器的速度慢。里我可以避免掉存分配
Write方法需要入一byte切片而我希望入的值是一字符串,所以我需要使用[]byte(...)进行转换。这个转换分配内存并且做一个拷贝,但是这个拷贝在转换后几乎立就被丢弃掉。让我们假装这是一web服器的核心部分且我的性能分析表示这个内存分配使服器的速度慢。里我可以避免掉存分配
這個io.Writer接口告訴我們關於w持有的具體類型的唯一西:就是可以向它入字切片。如果我們迴顧net/http包中的幕,我知道在這個程序中的w量持有的動態類型也有一個允許字符串高效入的WriteString方法這個方法避免去分配一個零時的拷。(可能像在黑夜中射擊一樣,但是許多滿足io.Writer接口的重要型同也有WriteString方法包括\*bytes.Buffer\*os.File和\*bufio.Writer。
这个io.Writer接口告诉我们关于w持有的具体类型的唯一西:就是可以向它入字切片。如果我们回顾net/http包中的幕,我知道在这个程序中的w量持有的动态类型也有一个允许字符串高效入的WriteString方法这个方法避免去分配一个零时的拷。(可能像在黑夜中射击一样,但是许多满足io.Writer接口的重要型同也有WriteString方法包括\*bytes.Buffer\*os.File和\*bufio.Writer。
不能任意io.Writer型的量w它也有WriteString方法。但是我可以定義一個隻有這個方法的新接口且使用類型斷言來檢測是否w的動態類型滿足這個新接口。
不能任意io.Writer型的量w它也有WriteString方法。但是我可以定义一个只有这个方法的新接口且使用类型断言来检测是否w的动态类型满足这个新接口。
```go
// writeString writes s to w.
@@ -44,9 +44,9 @@ func writeHeader(w io.Writer, contentType string) error {
}
```
了避免重複定義,我們將這個檢査移入到一個實用工具函writeString中但是它太有用了以致標準庫將它作io.WriteString函提供。是向一io.Writer接口入字符串的推方法。
了避免重复定义,我们将这个检查移入到一个实用工具函writeString中但是它太有用了以致标准库将它作io.WriteString函提供。是向一io.Writer接口入字符串的推方法。
這個例子的神奇之處在於沒有定了WriteString方法的標準接口和有指定它是一需要行爲的標準接口。而且一個具體類型隻會通過它的方法定它是否滿足stringWriter接口而不是任何它和這個接口型表明的關繫。它的意思就是上面的技術依賴於一個假設;這個假設就是,如果一個類型滿足下面的這個接口,然WriteString(s)就方法必和Write([]byte(s))有相同的效果。
这个例子的神奇之处在于没有定了WriteString方法的标准接口和有指定它是一需要行为的标准接口。而且一个具体类型只会通过它的方法定它是否足stringWriter接口而不是任何它和这个接口型表明的关系。它的意思就是上面的技术依赖于一个假设;这个假设就是,如果一个类型满足下面的这个接口,然WriteString(s)就方法必和Write([]byte(s))有相同的效果。
```go
interface {
@@ -55,11 +55,11 @@ interface {
}
```
管io.WriteString記録了它的假,但是調用它的函數極少有可能會去記録它們也做了同的假。定義一個特定型的方法式地取了特定行爲的協約。對於Go言的新手,特别是那些自有強類型語言使用背景的新手,可能會發現它缺乏式的意令人感到混,但是在實戰的過程中這幾乎不是一個問題。除了空接口interface{},接口型很少意外巧合地被實現
管io.WriteString记录了它的假,但是用它的函数极少有可能会去记录它们也做了同的假。定义一个特定型的方法式地取了特定行为的协约。对于Go言的新手,特别是那些自有强类型语言使用背景的新手,可能会发现它缺乏式的意令人感到混,但是在实战的过程中这几乎不是一个问题。除了空接口interface{},接口型很少意外巧合地被实现
上面的writeString函使用一個類型斷言來知道一普遍接口型的值是否滿足一更加具的接口型;且如果滿足,它使用這個更具接口的行爲。這個技術可以被很好的使用不論這個被詢問的接口是一個標準的如io.ReadWriter或者用戶定義的如stringWriter。
上面的writeString函使用一个类型断言来知道一普遍接口型的值是否足一更加具的接口型;且如果足,它使用这个更具接口的行为。这个技术可以被很好的使用不论这个被询问的接口是一个标准的如io.ReadWriter或者用户定义的如stringWriter。
也是fmt.Fprintf函數怎麽從其它所有值中區分滿足error或者fmt.Stringer接口的值。在fmt.Fprintf部,有一個將單個操作對象轉換成一字符串的步,像下面這樣
也是fmt.Fprintf函数怎么从其它所有值中区分满足error或者fmt.Stringer接口的值。在fmt.Fprintf部,有一个将单个操作对象转换成一字符串的步,像下面这样
```go
package fmt
@@ -75,6 +75,6 @@ func formatOneValue(x interface{}) string {
}
```
如果x滿足這個兩個接口型中的一,具體滿足的接口決定對值的格式化方式。如果都不滿足,默的case或多或少會統一地使用反射來處理所有的其它型;我可以在第12章知道具是怎麽實現的。
如果x满足这个两个接口型中的一,具体满足的接口决定对值的格式化方式。如果都不足,默的case或多或少会统一地使用反射来处理所有的其它型;我可以在第12章知道具是怎么实现的。
再一次的,它假任何有String方法的類型滿足fmt.Stringer中定的行爲,這個行爲會返迴一個適合打印的字符串。
再一次的,它假任何有String方法的类型满足fmt.Stringer中定的行为,这个行为会返回一个适合打印的字符串。