Go的CSP并發模型

成都創新互聯成都企業網站建設服務,提供成都網站設計、成都做網站網站開發,網站定制,建網站,網站搭建,網站設計,成都響應式網站建設公司,網頁設計師打造企業風格網站,提供周到的售前咨詢和貼心的售后服務。歡迎咨詢做網站需要多少錢:18982081108
Go實現了兩種并發形式。第一種是大家普遍認知的:多線程共享內存。其實就是Java或者C++等語言中的多線程開發。另外一種是Go語言特有的,也是Go語言推薦的:CSP(communicating sequential processes)并發模型。
CSP 是 Communicating Sequential Process 的簡稱,中文可以叫做通信順序進程,是一種并發編程模型,由 Tony Hoare 于 1977 年提出。簡單來說,CSP 模型由并發執行的實體(線程或者進程)所組成,實體之間通過發送消息進行通信,這里發送消息時使用的就是通道,或者叫 channel。CSP 模型的關鍵是關注 channel,而不關注發送消息的實體。 Go 語言實現了 CSP 部分理論 。
“ 不要以共享內存的方式來通信,相反, 要通過通信來共享內存。”
Go的CSP并發模型,是通過 goroutine和channel 來實現的。
goroutine 是Go語言中并發的執行單位。其實就是協程。
channel是Go語言中各個并發結構體(goroutine)之前的通信機制。 通俗的講,就是各個goroutine之間通信的”管道“,有點類似于Linux中的管道。
Channel
Goroutine
goroutine和channel是Go語言非常棒的特色,它們提供了一種非常輕便易用的并發能力。但是當您的應用進程中有很多goroutine的時候,如何在主流程中等待所有的goroutine 退出呢?
1 通過Channel傳遞退出信號
Go的一大設計哲學就是:通過Channel共享數據,而不是通過共享內存共享數據。主流程可以通過channel向任何goroutine發送停止信號,就像下面這樣:
func run(done chan int) {
for {
select {
case -done:
fmt.Println("exiting...")
done - 1
break
default:
}
time.Sleep(time.Second * 1)
fmt.Println("do something")
}
}
隨便怎么寫啊,共享內存獲取到不是給你一個內存地址,這里稱之為des么,直接通過des地址訪問啊,比如你要寫2個結構體進去,第一個memcpy寫到des,第二個可以(memcpy到des+結構體大小)的地址指向的內存上,
網站欄目:go語言共享內存 go 內存拷貝
網站網址:http://www.yijiale78.com/article28/doddgjp.html
成都網站建設公司_創新互聯,為您提供網站建設、服務器托管、微信小程序、微信公眾號、小程序開發、云服務器
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯