第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Go中的數(shù)據(jù)競(jìng)賽:為什么它發(fā)生在10-11ms以下?

Go中的數(shù)據(jù)競(jìng)賽:為什么它發(fā)生在10-11ms以下?

Go
慕哥9229398 2022-09-26 14:16:08
這是我運(yùn)行的代碼:package mainimport (    "fmt"    "time")const delay = 9 * time.Millisecondfunc main() {    n := 0    go func() {        time.Sleep(delay)        n++    }()    fmt.Println(n)}這是我使用的命令:go run -race data_race_demo.go以下是我注意到的行為:設(shè)置為 9ms 或更低時(shí),始終會(huì)檢測(cè)到數(shù)據(jù)爭(zhēng)用(程序拋出delayFound 1 data race(s))設(shè)置為 12ms 或更高時(shí),永遠(yuǎn)不會(huì)檢測(cè)到數(shù)據(jù)競(jìng)速(程序只是打印delay0)設(shè)置為 10 到 11 毫秒時(shí),數(shù)據(jù)爭(zhēng)用會(huì)間歇性地發(fā)生(即,有時(shí)打印,有時(shí)拋出delay0Found 1 data race(s))為什么這種情況發(fā)生在10-11ms左右?我正在使用Go 1.16.3,如果這很重要的話。darwin/amd64
查看完整描述

1 回答

?
開滿天機(jī)

TA貢獻(xiàn)1786條經(jīng)驗(yàn) 獲得超13個(gè)贊

你有2個(gè)哥律:和你啟動(dòng)的那個(gè)。他們?cè)跊]有同步的情況下訪問變量(一個(gè)是寫入):這是一場(chǎng)數(shù)據(jù)競(jìng)賽。mainn

是否檢測(cè)到此種族取決于是否發(fā)生此不雅訪問。當(dāng) main() 函數(shù)結(jié)束時(shí),你的應(yīng)用也會(huì)結(jié)束,它不會(huì)等待其他非 goroutine 完成。main

如果增加睡眠延遲,將比睡眠結(jié)束更早結(jié)束,并且不會(huì)等待不雅的寫入發(fā)生,因此不會(huì)檢測(cè)到任何內(nèi)容。如果睡眠時(shí)間較短,短于執(zhí)行時(shí)間,則會(huì)發(fā)生不雅的寫入并被檢測(cè)到。main()n++fmt.Prinln()

10ms沒什么特別的。這只是在您的環(huán)境中執(zhí)行和終止應(yīng)用所需的大致時(shí)間。如果在語句之前執(zhí)行其他“冗長(zhǎng)”的任務(wù),例如:fmt.Println()Println()

for i := 0; i < 5_000_000_000; i++ {
}
fmt.Println(n)

即使睡眠時(shí)間為 50 毫秒,也會(huì)檢測(cè)到比賽(因?yàn)樵撗h(huán)需要一些時(shí)間來執(zhí)行,從而允許在讀取調(diào)用和應(yīng)用終止之前發(fā)生不雅的寫入)。(一個(gè)簡(jiǎn)單的方法也可以,我只是不希望任何人得出錯(cuò)誤的結(jié)論,即他們以某種方式“互動(dòng)”彼此。nfmt.Println()time.Sleep()


查看完整回答
反對(duì) 回復(fù) 2022-09-26
  • 1 回答
  • 0 關(guān)注
  • 85 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)