<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??一站式輕松地調用各大LLM模型接口,支持GPT4、智譜、豆包、星火、月之暗面及文生圖、文生視頻 廣告
                共享內存并發機制 === > 像java這樣的語言實現并發就涉及共享資源,為了保證資源的安全性就要用到鎖 go 并發之間的通訊可以用channel吧并行數據轉變為串行數據,我們還是向講一講老的處理方案 ### Package Sync包中有兩個鎖 一個是Mutex 互斥寫鎖 一個是RWLock 讀寫鎖 沒有鎖的下場 ~~~ func TestCounter(t *testing.T) { counter := 0 var wg sync.WaitGroup for i := 0;i<5000;i++ { wg.Add(1) go func() { counter++ wg.Done() }() } wg.Wait() t.Log(counter) } ~~~ ![](https://box.kancloud.cn/00a94ed3dbda3f69129ecb46a08cc42a_729x631.png) 這個根本就不對阿! 哈哈哈 有可能幾個協程同時寫導致的 所以我們要使用鎖來實現 我們向計算以下這個程序的時間 ~~~ func TestCounter(t *testing.T) { nowTime := time.Now().UnixNano() counter := 0 var wg sync.WaitGroup for i := 0;i<5000;i++ { wg.Add(1) go func() { counter++ wg.Done() }() } wg.Wait() t.Log(counter) tTime := time.Now().UnixNano() fmt.Println("time: ",(tTime - nowTime)) } ~~~ 這里用nano秒來計算,為什么了go太快了 現在測試結果是: ``` === RUN TestCounter time: 2071910 --- PASS: TestCounter (0.00s) share_test.go:28: 4334 PASS ``` ### 我們現在加上鎖 ~~~ func TestMutCounter(t *testing.T) { nowTime := time.Now().UnixNano() var nut sync.Mutex counter := 0 var wg sync.WaitGroup for i := 0;i<5000;i++ { wg.Add(1) go func() { nut.Lock() defer nut.Unlock() counter++ wg.Done() }() } wg.Wait() t.Log(counter) tTime := time.Now().UnixNano() fmt.Println("time: ",(tTime - nowTime)) } ~~~ 現在的返回結果 ``` === RUN TestMutCounter time: 2151931 --- PASS: TestMutCounter (0.00s) share_test.go:48: 5000 PASS ``` 答案是對了但是大家有沒有發現這個時間,比上一個沒有加鎖的時間多 這個就鎖帶來的性能消耗 為了解決這個問題我們用讀寫鎖來實現一遍 看下面的RWMutex
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看