管道是內(nèi)核維護(hù)的一個(gè)緩存,它提供兩個(gè)fd,從一個(gè)fd寫入數(shù)據(jù),從另一個(gè)fd讀出數(shù)據(jù). 所以它是半雙工的。
如果把線程安全定義為允許多個(gè)goroutine同時(shí)去讀寫,那么golang 的channel 是線程安全的。不需要在并發(fā)讀寫同一個(gè)channe時(shí)加鎖。
golang中的channel
channel用于goroutine之間的通信
如果不用channel,使用共享全局變量的方式,需要加鎖
// synchornized 同步 // golang中的 sync包中有互斥鎖 var lock sync.Mutex // mutex 互斥 lock.Lock() // 上鎖 // 多個(gè)goroutine同時(shí)對相同的數(shù)據(jù)進(jìn)行修改 lock.Unlock() // 解鎖
使用同步鎖并發(fā)效率會很低
channel主要用于goroutine通信和解決主線程等待goroutine執(zhí)行結(jié)束再退出的問題
basic concept of channel
本質(zhì)上是一個(gè)FIFO的數(shù)據(jù)結(jié)構(gòu)-隊(duì)列
線程安全,不需要加鎖
channel是有類型的,如字符串channel chan string,只能保存string數(shù)據(jù)
以上就是golang 管道線程安全嗎的詳細(xì)內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!
網(wǎng)頁題目:go語言的管道線程安全-創(chuàng)新互聯(lián)
網(wǎng)頁URL:http://m.2m8n56k.cn/article14/cciige.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、全網(wǎng)營銷推廣、軟件開發(fā)、手機(jī)網(wǎng)站建設(shè)、動態(tài)網(wǎng)站、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容