亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么即使有鎖,GO 也會因“并發映射寫入”而恐慌?

為什么即使有鎖,GO 也會因“并發映射寫入”而恐慌?

Go
12345678_0001 2023-04-24 16:03:04
當嘗試將此結構與多個 goroutine 一起使用時,有時我會遇到以下錯誤之一:fatal error: concurrent map read and map write或者concurrent map writes閱讀此線程后,我確保在構造函數中返回一個引用并將引用傳遞給接收者。使用它的全部代碼都在這個 github repo中type concurrentStorage struct {    sync.Mutex    domain string    urls map[url.URL]bool}func newConcurrentStorage(d string) *concurrentStorage{    return &concurrentStorage{        domain: d,        urls: map[url.URL]bool{},    }}func (c *concurrentStorage) add(u url.URL) (bool) {    c.Lock()    defer c.Unlock()    if _, ok := c.urls[u]; ok{        return false    }    c.urls[u] = true    return true}
查看完整描述

1 回答

?
翻翻過去那場雪

TA貢獻2065條經驗 獲得超14個贊

在閱讀您鏈接到的 Github 上的代碼后,該crawl()函數接受一個concurrentStorage(不是指針)。

*urlSet對于調用 時的每個取消引用(即:)crawl(),您正在復制concurrentStorage結構(包括sync.Mutex),而地圖保留指向原始結構的指針。這意味著您的互斥體與每個 goroutine 是隔離的,同時它們共享相同的狀態。

如果您更改crawl()為接受指針,并停止取消引用concurrentStorage,它將按您的預期工作。


查看完整回答
反對 回復 2023-04-24
  • 1 回答
  • 0 關注
  • 128 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號