偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

為什么 Go 不支持循環(huán)引用?

開(kāi)發(fā) 后端
在程序中,如果我們頻繁的出現(xiàn)模塊與模塊之間的循環(huán)引用,這時(shí)候我們是不是應(yīng)該考慮一下,是不是設(shè)計(jì)的有些問(wèn)題,要不要考慮調(diào)整?

[[431435]]

本文轉(zhuǎn)載自微信公眾號(hào)「腦子進(jìn)煎魚(yú)了」,作者陳煎魚(yú)。轉(zhuǎn)載本文請(qǐng)聯(lián)系腦子進(jìn)煎魚(yú)了公眾號(hào)。

大家好,我是煎魚(yú)。

學(xué)習(xí) Go 語(yǔ)言的開(kāi)發(fā)者越來(lái)越多了,很多小伙伴在使用時(shí),就會(huì)遇到種種不理解的問(wèn)題。

其中一點(diǎn)就是包的循環(huán)引用的報(bào)錯(cuò):

  1. package command-line-arguments 
  2.  imports github.com/eddycjy/awesome-project/a 
  3.  imports github.com/eddycjy/awesome-project/b 
  4.  imports github.com/eddycjy/awesome-project/a: import cycle not allowed 

一下子就很懵逼了,為什么 Go 不支持包之間的循環(huán)引用呢,這就很不解了,難道還影響性能了?

如下圖:

圖來(lái)自網(wǎng)絡(luò)

今天煎魚(yú)將和大家一起了解背后的原因。

案例演示

這里我們做一個(gè)基本的案例 Demo,便于沒(méi)接觸過(guò)的同學(xué)建立初步認(rèn)知。我們的程序分別有 2 個(gè) package。

package a 的代碼如下:

  1. import ( 
  2.  "github.com/eddycjy/awesome-project/b" 
  3.  
  4. func Hello(s string) { 
  5.  b.Print(s) 

package b 的代碼如下:

  1. import ( 
  2.  "fmt" 
  3.  
  4.  "github.com/eddycjy/awesome-project/a" 
  5.  
  6. func Hello() { 
  7.  a.Hello("腦子進(jìn)煎魚(yú)了"
  8.  
  9. func Print(s string) { 
  10.  fmt.Println(s) 

再在 main.go 的文件中調(diào)用 a.Hello("腦子進(jìn)煎魚(yú)了") 方法。

一運(yùn)行,就會(huì)出現(xiàn)如下錯(cuò)誤提示:

  1. package command-line-arguments 
  2.  imports github.com/eddycjy/awesome-project/a 
  3.  imports github.com/eddycjy/awesome-project/b 
  4.  imports github.com/eddycjy/awesome-project/a: import cycle not allowed 

錯(cuò)誤的本質(zhì)原因是 package a 引用了 package b,而 package b 又引用了 package a,造成了循環(huán)引用。

這在 Go 語(yǔ)言中是明令禁止的,在編譯時(shí)就會(huì)中斷程序,導(dǎo)致編譯失敗。

原因分析

根據(jù)現(xiàn)在 Go 官方的統(tǒng)一意見(jiàn)來(lái)看,package 循環(huán)導(dǎo)入幾乎不可能出現(xiàn),即使是 Go2,也被明確拒絕了。

因?yàn)?Go2 可能是很多核心問(wèn)題的破變的關(guān)鍵節(jié)點(diǎn),有許多人提了類(lèi)似《proposal: Go 2: allow import cycle》的提案,希望解決循環(huán)引入的問(wèn)題。

Go 語(yǔ)言之父 Rob Pike 親自回答了這個(gè)問(wèn)題,原因如下:

  • 沒(méi)有支持循環(huán)引用:目的是迫使 Go 程序員更多地考慮程序的依賴(lài)關(guān)系。
    • 保持依賴(lài)關(guān)系圖的簡(jiǎn)潔。
    • 快速的程序構(gòu)建。
  • 如果支持循環(huán)引用:很容易會(huì)造成懶惰、不良的依賴(lài)性管理和緩慢的構(gòu)建。這是設(shè)計(jì)者不希望看見(jiàn)的。
    • 混亂的依賴(lài)關(guān)系。
    • 緩慢的程序構(gòu)建

因此考慮一開(kāi)始就保持依賴(lài)圖的正確 DAG,Rob Pike 認(rèn)為這是一個(gè)值得預(yù)先簡(jiǎn)化的領(lǐng)域。

在 Go 程序中去做導(dǎo)入循環(huán)這件事可能很方便,但背后的代價(jià)可能是災(zāi)難性的,會(huì)對(duì) Go 的構(gòu)建性能和依賴(lài)關(guān)系造成非常不利的影響。

所以在 Go 中被明確禁止支持。

總結(jié)

在程序中,如果我們頻繁的出現(xiàn)模塊與模塊之間的循環(huán)引用,這時(shí)候我們是不是應(yīng)該考慮一下,是不是設(shè)計(jì)的有些問(wèn)題,要不要考慮調(diào)整?

但也并非所有的事都是二極管,Go 源碼可能或多或少都有自己循環(huán)引用的案例,最重要的是想清楚。

 

責(zé)任編輯:武曉燕 來(lái)源: 腦子進(jìn)煎魚(yú)了
相關(guān)推薦

2021-12-09 10:51:47

Go類(lèi)繼承

2021-12-15 07:49:22

Go語(yǔ)言設(shè)計(jì)

2023-01-28 08:05:32

轉(zhuǎn)換Go泛型

2024-01-01 08:10:40

Go語(yǔ)言map

2024-01-05 08:45:35

Go語(yǔ)言map

2024-05-28 08:55:52

2021-11-08 11:02:01

Go函數(shù)重載

2023-02-26 23:36:08

PHPGo函數(shù)

2024-03-08 08:51:59

Gomain函數(shù)

2020-07-22 08:01:41

Python開(kāi)發(fā)運(yùn)算符

2020-10-09 06:48:19

Pythonswitch語(yǔ)句

2024-03-12 09:13:28

Go語(yǔ)言main

2021-02-01 13:53:53

StringlongJava

2009-03-12 08:42:38

AndroidWMMTK

2021-06-11 00:03:31

鴻蒙智能手機(jī)

2021-08-02 09:31:20

Python工具代碼

2021-07-13 08:09:34

微博推特評(píng)論

2025-06-26 02:22:00

GoProtobuf標(biāo)簽

2023-04-03 11:21:29

PythonGoRust

2009-03-11 17:32:22

聯(lián)發(fā)科WMAndroid
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)