3 回答

TA貢獻(xiàn)1818條經(jīng)驗(yàn) 獲得超8個(gè)贊
go.sum
包含特定模塊版本內(nèi)容的預(yù)期加密校驗(yàn)和。每次使用依賴(lài)項(xiàng)時(shí),如果缺少或需要匹配 go.sum 中的現(xiàn)有條目,則將其校驗(yàn)和添加到 go.sum。
每個(gè)包/模塊都是依賴(lài)項(xiàng),每個(gè)依賴(lài)項(xiàng)都意味著使用校驗(yàn)和進(jìn)行維護(hù),go.sum
因此無(wú)論是包還是模塊,它都會(huì)被維護(hù)。
源將相應(yīng)地下載到$GOPATH/src
目錄中。
嘗試 -

TA貢獻(xiàn)1943條經(jīng)驗(yàn) 獲得超7個(gè)贊
因?yàn)樵?code>go.sum文件中寫(xiě)入了每個(gè)依賴(lài)項(xiàng)和哈希。與您的go.mod
文件相關(guān)的一個(gè),以及從您導(dǎo)入的模塊中導(dǎo)入的一個(gè)。嘗試運(yùn)行go mod tidy
以減少導(dǎo)入的模塊,您的go.mod
文件將包含一些//indirect
導(dǎo)入,這是您導(dǎo)入的模塊在內(nèi)部使用的那個(gè)。

TA貢獻(xiàn)1796條經(jīng)驗(yàn) 獲得超4個(gè)贊
或許Golang源碼可以說(shuō)明原因:
func (r *codeRepo) legacyGoMod(rev, dir string) []byte {
// We used to try to build a go.mod reflecting pre-existing
// package management metadata files, but the conversion
// was inherently imperfect (because those files don't have
// exactly the same semantics as go.mod) and, when done
// for dependencies in the middle of a build, impossible to
// correct. So we stopped.
// Return a fake go.mod that simply declares the module path.
return []byte(fmt.Sprintf("module %s\n", modfile.AutoQuote(r.modPath)))
}
來(lái)自這里的代碼:https ://github.com/golang/go/blob/acac535c3ca571beeb168c953d6d672f61387ef1/src/cmd/go/internal/modfetch/coderepo.go#L857
↓ VSCode 打開(kāi)/usr/local/go/src
:
定位到
cmd/go/internal/modfetch/coderepo.go
,給func添加斷點(diǎn)legacyGoMod
定位到
cmd/go/internal/modfetch/coderepo_test.go
,按 F5稍等片刻,停在斷點(diǎn)處
- 3 回答
- 0 關(guān)注
- 255 瀏覽
添加回答
舉報(bào)