循环依赖给cpp的编译带来错误,明明include了,编译器非要说没有。
例如类C继承自A,B引用了A,C又引用了B。这里面顺序不重要,总存在一定的可能性出现undefine reference问题。
解决方法是:除了include必要的文件之外,谁找不到,就在前面加一句声明。例如C里面找不到B,那么C文件报错,那么就在出错的文件中加一句单纯的声明,告诉编译器,真的有这个 :
class B;
在CMake管理项目文件的时候,可能在link阶段出现类似前面编译期间出现的雷同错误,也是undefined reference。这个问题解决就复杂了。有关循环依赖的问题,在编译出错时,只用声明语句就可以解决,但在库连接的时候就存在一个先有蛋还是先有鸡的问题,永远在循环。
解决的时候,注意有两点:
1,target_link_libraries()里面必须使用倒序,越基础的库越往后放。
2,如果库存在B被A引用,A被B引用。C引用A和B的时候,循环引用造成的undefine reference错误。解决方案:
- 给一个库A设置一个扩展库,或者说全引用库AandB(重点看第二句)
add_library ( A SHARED ${ A_src} )
set_target_properties ( A PROPERTIES OUTPUT_NAME AandB )
# 这里SHARE和STATIC都可以用这个方法
- B中正常引用A
- AandB再次引用B,这样AandB中就包含了A和B的全部内容。
add_library ( AandB SHARED ${A_src} ) target_link_libraries ( A B )
可以看到A和AandB用的代码是一样的。但A库不全,AandB库包含了A和B的内容。
-
C可引用AandB库,把循环引用问题放入同一个库中:AandB封装了循环引用。