目錄:
前幾天GCC4.8發布, 已經部分包含Go1.1特性, 詳細介紹:
根據golang-nuts的消息, 4月第1周可能會進入Go1.1發布流程(就是下周). 要修復的問題還剩20多一點的, 估計應該不會出現大的延期.
補充: Go1.1正式版本已經於2013.05.14正式發布.
補充: 目前還標記為Go1.1的剩余BUG主要是gccgo相關的, gccgo1.1的發布流程和GCC4.8.1同步.
Go1.1主要的目標是性能的優化和一些bug的修復, 詳細內容參考:
關於Go的性能測試數據(性能和C語言gcc -O2
性能基本沒有差異):
補充: BenchmarksGame的測試不同語言實現差別較大, 比如: Go的binary-trees開了很多goroutine, C的程序開了omp優化等.
Go1.1的更新主要涉及 語言/實現/性能優化/標准庫 幾個部分.
補充: Go1.1的二進制安裝包將包含gotour程序(啟動命令: go tool tour
).
Go1發布時曾作出承諾, 保證在Go1.x發布後不會修改之前的語言特性. 這裡有一些問題的修復, 還有一些新增加的特性.
在Go1中, 整數被一個常量0除會導致一個運行時 panic
:
func f(x int) int {
return x/0
}
在 Go1.1 中, 整數被一個常量0將會被當作一個編譯錯誤處理.
字符串和 rune
字面值的定義更加嚴格. Unicode代理區碼點不能用於面值. 細節請參考後面的 Unicode 章節.
Go1.1新實現了方法值(method values), 它是綁定到receiver值的一個閉包. 比如有一個實現了Writer
的 w
值, 那麼 w.Write
將等價於下面的閉包函數:
func (p []byte) (n int, err error) {
return w.Write(p)
}
方法值(method values)不同於方法表達式(method expressions), 方法表達式是從一個類型對應的函數. 比如 (*bufio.Writer).Write
和下面的普通函數類型:
func (w *bufio.Writer, p []byte) (n int, err error) {
return w.Write(p)
}
更新: 現有的代碼不需要更新, 這個是新加的特性.
GoSpec中給出了很多例子:
f := t.Mv; f(7) // like t.Mv(7)
f := pt.Mp; f(7) // like pt.Mp(7)
f := pt.Mv; f(7) // like (*pt).Mv(7)
f := t.Mp; f(7) // like (&t).Mp(7)
f := makeT().Mp // invalid: result of makeT() is not addressable
有了方法值, Go1.1可以從interface值中取出方法值(Go1.0不支持方法值):
var i interface { M(int) } = myVal
f := i.M; f(7) // like i.M(7)
這樣改動的好處是類型的方法和interface
方法完全統一了.
在Go1.1之前, 函數如果有返回值的話, 則最後必須有一個retune或panic語句.
func abs(x int) int {
if x >= 0 {
return x
} else {
return -x
}
}
會有以下編譯錯誤:
function ends without a return statement
之前一般可以在末尾加一個panic來回避這個問題:
func abs(x int) int {
if x >= 0 {
return x
} else {
return -x
}
panic("not reachable")
}
在Go1.1規范, 對函數的終結語句做了定義:
主要有以下幾種類型:
已有的代碼可以不用更新, 當然有些代碼可以寫的更簡化.