昨天我遇到了一个很奇怪的bug,事情经过是这样的,我用Qt编写了一个动态库,这里称之为lib,lib中有多个界面,相应的我也在这些界面中加了一些图标。首先,我是在Windows下使用Qt MSVC编译器编译的,libA编译完成以后,我通过另一个程序(这里称之为app)来调用它,在app中通过调用lib的接口来显示lib中的界面,此时一切正常,界面、图标、功能都和预期的一样。
然后我将上述两个工程拷贝到Linux系统下,使用Qt gcc进行编译,编译也没问题,运行起来界面、功能也一切正常,但是所有的图标都不显示。
此时,我并不觉得是什么大问题,感觉马上就能解决掉,于是我先检查了一下资源是否拷贝完整,然后执行qmake,再重新构建。运行一下,问题还在。
还是不慌,此时我想明确一下问题是出在动态库lib上还是应用程序app上,于是我就用Qt新建了一个界面程序,添加库lib,包含头文件,然后接口调用,编译运行后,图标都显示正常,没有出现任何问题。于是就确定了问题出在了app上。
然后我就去检查了一下依赖库,是不是缺少imageformats文件夹,没发现问题。于是就开始检查代码。因为我在app中使用了qss进行样式的设置,以我以前的经验来看,可能是样式表再作怪,如是我注释了样式表设置代码,编译运行后,问题还在。
代码查来查去,没发现什么问题,于是开始重新梳理思路。图标不显示,要么是资源问题,要么是依赖的问题,通过上面的检查过程可以确定依赖没问题,只能是资源出了问题。我的所有资源都添加在images.qrc中,我将images.qrc中的所有图片资源全部删除,然后重新添加,再次编译后,问题还是没解决。
奇了个大怪,怎么会这样,不信邪的我,又打开了上面刚创建的测试动态库是否正常的工程,添加Qt资源文件,按照习惯命名为images,然后往里面添加相同的图片,然后编译运行,动态库中的界面谈了出来,但是图标不见了。问题就出现在这个images.qrc中,离真相已经很近了,心情还有点小激动呢。
那么images.qrc有什么问题呢,首先图片肯定不会对程序造成影响,那么就是images.qrc本身的原因,再看一下lib下的资源文件也叫images.qrc,难道是重名的原因,将app中的images.qrc改为app_images.qrc,重新编译运行,图标出现,问题解决。
至于具体原因,网上也没查到确切的说法,但是因为只有Linux下有问题,且又是重名时出现,那多少时链接出现了错误,具体原因待我查到以后,放在评论中。