二进制兼容的定义
一个连接到旧版本的动态库的应用程序,无需重新编译就可以用新版本的动态库运行,则这个库被认为是二进制兼容的。
一个连接到旧版本的动态库的应用程序,无需修改源码单需要重新编译后可以用新版本的动态库运行,则这个库被认为是源码兼容的。
结合网上众多文章,记录一下个人理解。
定义在头文件的(即暴露给应用程序的)结构体(类)在内存中布局如果没有发生改变,则这个类是二进制兼容的。
Qt的D指针
Qt库的大版本内是二进制兼容的。Qt中的类很多都是使用D指针来达到二进制兼容。D指针指向一个私有的数据结构(或者类),这个私有的数据结构保存不应该暴露给库使用者的数据,因此这部分数据可以在后续的功能更新中改变而不影响使用者。个人理解可以认为暴露给使用者的类是一个壳,而这个不暴露的私有类则是真正的数据。类通过D指针访问私有类的数据和方法,与D指针对应,私有类通过Q指针访问暴露的类。
参考两篇文章:
什么是d-pointer
Policies/Binary Compatibility Issues With C++