相信不少初学者 在写 Golang 程序都遇到过 import cycle not allowed 问题。
1. 循环依赖问题如何分析
假设有如下使用场景:
- A 是应用程序的框架级结构体,在 A 包含子模块 B 和 C 的指针;
- B 为了方便的使用应用的其他子模块(比如 C )功能,所以在其结构体包含了 A 的指针;
- C 要调用 A 包中的某个方法;
代码实现
其程序大致如下:
package a 代码如下:
package a
 
import (
 "fmt"
 
 "github.com/ggq89/mutualdep/b"
 "github.com/ggq89/mutualdep/c"
)
 
type A struct {
 Pb *b.B
 Pc *c.C
}
 
func New(ic int) *A {
 a := &A{
 Pc: c.New(ic),
 }
 
 a.Pb = b.New(a)
 
 return a
}
 
func Printf(v int) {
 fmt.Printf("%v", v)
}package b 代码如下:
package b
 
import (
 "github.com/ggq89/mutualdep/a"
)
 
type B struct {
 Pa *a.A
}
 
func New(a *a.A) *B {
 return &B{
 Pa: a,
 }
}
 
func (b *B) DisplayC() {
 b.Pa.Pc.Show()
}package c 代码如下:
package c
 
import "github.com/ggq89/mutualdep/a"
 
type C struct {
 Vc int
}
 
func New(i int) *C {
 return &C{
 Vc: i,
 }
}
 
func (c *C) Show() {
 a.Printf(c.Vc)
}package a 依赖 package b 和 package c,同时 package b 依赖 package a 、 package c 也依赖 package a
main 函数代码如下:
package main
 
import "github.com/ggq89/mutualdep/a"
 
func main() {
 a := a.New(3)
 a.Pb.DisplayC()
}编译时就会报错如下:
import cycle not allowed
package main
    imports github.com/ggq89/mutualdep/a
    imports github.com/ggq89/mutualdep/b
    imports github.com/ggq89/mutualdep/a2. 如何解决循环依赖
基本思路
- 定义 interface
- 分包
基本思想
- 对于软相互依赖,利用分包的方法就能解决,有些函数导致的相互依赖只能通过分包解决;分包能细化包的功能;
- 对于硬相互依赖只能通过定义接口的方法解决;定义接口能提高包的独立性,同时也提高了追踪代码调用关系的难度;
相关文章
- Golang报“import cycle not allowed”错误的2种解决方法_Golang_脚本之家
有问题会及时更新...










