为什么GO不支持循环引用
目录
- 1、案例演示
- 2、原因分析
- 3、总结
其中一点就是包的循环引用的报错:
package command-line-arguments imports github.com/eddycjy/awesome-project/a imports github.com/eddycjy/awesome-project/b imports github.com/eddycjy/awesome-project/a: import cycle not allowed
一下子就很懵逼了,为什么 Go 不支持包之间的循环引用呢,这就很不解了,难道还影响性能了?
如下图:
文章图片
今天煎鱼将和大家一起了解背后的原因。
1、案例演示 这里我们做一个基本的案例
Demo
,便于没接触过的同学建立初步认知。我们的程序分别有 2 个 package
。package a
的代码如下:import ( "github.com/eddycjy/awesome-project/b")func Hello(s string) { b.Print(s)}
package b 的代码如下:
import ( "fmt" "github.com/eddycjy/awesome-project/a")func Hello() { a.Hello("脑子进煎鱼了")}func Print(s string) { fmt.Println(s)}
再在
main.go
的文件中调用 a.Hello
("脑子进煎鱼了") 方法。一运行,就会出现如下错误提示:
package command-line-arguments错误的本质原因是
imports github.com/eddycjy/awesome-project/a
imports github.com/eddycjy/awesome-project/b
imports github.com/eddycjy/awesome-project/a: import cycle not allowed
package a
引用了 package b
,而 package b
又引用了 package a
,造成了循环引用。这在 Go 语言中是明令禁止的,在编译时就会中断程序,导致编译失败。
2、原因分析 根据现在 Go 官方的统一意见来看,
package
循环导入几乎不可能出现,即使是 Go2,也被明确拒绝了。【为什么GO不支持循环引用】因为 Go2 可能是很多核心问题的破变的关键节点,有许多人提了类似《proposal: Go 2: allow import cycle》的提案,希望解决循环引入的问题。
Go 语言之父
Rob Pike
亲自回答了这个问题,原因如下:没有支持循环引用:目的是迫使 Go 程序员更多地考虑程序的依赖关系。
- 保持依赖关系图的简洁。
- 快速的程序构建。
- 混乱的依赖关系。
- 缓慢的程序构建
DAG
,Rob Pike
认为这是一个值得预先简化的领域。在 Go 程序中去做导入循环这件事可能很方便,但背后的代价可能是灾难性的,会对 Go 的构建性能和依赖关系造成非常不利的影响。
所以在 Go 中被明确禁止支持。
3、总结 在程序中,如果我们频繁的出现模块与模块之间的循环引用,这时候我们是不是应该考虑一下,是不是设计的有些问题,要不要考虑调整?
但也并非所有的事都是二极管,Go 源码可能或多或少都有自己循环引用的案例,最重要的是想清楚。
到此这篇关于为什么GO不支持循环引用的文章就介绍到这了,更多相关GO不支持循环引用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 为什么你的路演总会超时()
- 财商智慧课(六)
- 吃了早餐,反而容易饿(为什么?)
- 为什么越花钱的人越有钱,越舍不得花钱的人却越穷()
- dubbo基本认识
- 为什么985/211的学生能胜任工作获得老板的青睐。
- 年轻人,干了孤独这杯酒
- 为什么孩子一定要学会可视化思维!
- 关于this的一些问题(1)
- 为什么有些女孩喜欢看玛丽苏爱情片()