※ 引述《LinuxKernel (Linus Torvalds)》之銘言:
: 不敢說會寫,只能說略懂,以下簡單分享。
: 先說覺得好的地方
: 1. 對 non-blocking 的封裝
: 大家都知道在 C/C++ 底下要寫出高併發性能的 server 很多細節是很麻煩的
: 你可能說寫 server 不就開個 socket 搭配 fork 多麼直觀
: 但現實是要達到好的性能就需要 select、epoll、kqueue 甚至 thread pool 之類的東西
: 但 non-blocking 的世界畢竟不是那麼直觀
: Go 強的地方就在於他讓你用很直觀的 blocking 寫法
: 一個 client 進來你也就像 fork 一樣給他開個 goroutine
: 但實際上它底層 runtime 就是用 epoll/kqueue 幫你做掉
: 也幫你做這些 lightweight thread 的 scheduling
: 當然 C/C++ 的世界也有類似的 library 可以辦到,像是 Boost.Fiber
: 但 Go 裡面用 goroutine 搭配 channel 感覺就是優雅了些
: 不過 goroutine 還是有可能踩到坑的
: 例如 goroutine 就永遠卡在那邊,這點可以去了解一下它 scheduling 的實作
goroutine應該說是preemptible blocking. epoll是io的部份,跟goroutine
無關。
Boost.fiber 是coroutine. 打個比喻就是win3.1的 cooperative multitasking.
goroutine 是 win95 的preemptive multitasking.完全不同等級的概念。
goroutine應該是模仿Erlang的process. channel就是message passing.
簡單來講golang就是better c + gc + concurrency.
goroutine 其實是golang的最重要功能。寫過Multithread的人都知道,
盡量不要share memory. Lock carfully(avoid 2 locks if possible),
wait as little as possible.
Multithread是very HARD(tm)的,bug非常難找,真的極少人寫的好。
寫過Erlang的人都知道, concurrency is SIMPLE. golang也是
同樣的.
為什麼goroutine is SIMPLE, multithread is HARD. 重點就是channel,
(Message Passing). 只要不要share data. concurrency就簡單了。
我們都知道Moore's Law is dead. 以後multi-core只會越來越多,
cpu的frequency不會增加太多。Concurrency programming只會越來越重要,
Erlang證明它的concurrency programming model work. Golang 是
google想辦法把concurrency programming 帶到大家能用的語言上來。
我覺得golang用的人會越來越多。它其實是真的c的後繼語言。
大大推薦。
-補充一下