最近在做Qt-vs项目时遇到这个问题,最初以为是比较经典的库引用问题,在反复的查找工程配置信息时,并没有发现什么特别的问题。在网上找了半天,也没有发现特别对症的方法,所以总结一下这个工程奇怪的现象。

环境:VS2017、Qt5.12.4、QtVSTool2.4.2

问题现象:

第一次编译,出现问题,如果第二次不选择重新生成,而是选择生成,则系统可以正确编译。当再次选择重新生成时,重复出现如下问题。

9df39203976622d57d4768dffbd89174.png

1>MusicTimer.vcxproj -> E:WorkMusicTimerx64DebugMusicTimer.exe

1>LINK : error LNK2001: 无法解析的外部符号 WinMainCRTStartup

1>E:WorkMusicTimerx64DebugMusicTimer.exe : fatal error LNK1120: 1 个无法解析的外部命令

1>已完成生成项目“MusicTimer.vcxproj”的操作 - 失败。

========== 全部重新生成: 成功 0 个,失败 1 个,跳过 0 个 ==========

问题总结为:编译器找不到入口函数,工程编译失败。

最开始以为是Qt的插件问题,因为该版本的Qt VS Tool 生成的工程是这种类型的,对这块分析的比较少

308d76bcb2851bc54730b324b46214d5.png

在预处理定义的时候,使用的是“$(Qt_DEFINES_);%(PreprocessorDefinitions)”这个东西,并不是以前熟悉的“UNICODE _UNICODE WIN32 _ENABLE_EXTENDED_ALIGNED_STORAGE WIN64”这种定义。

所以问题不是太好找。

后来就使用了最笨的一种方法:逐步排除(将工程里的源文件,逐步移除掉)。

首先,新建一个简单的Qt程序,发现改程序可以正常的编译执行。说明编译环境和操作系统环境变量没有问题。

然后,将工程里的其他源文件全部移除,只剩下Qt的main.cpp(如开头的问题现象图片)。

发现编译仍然出现问题。于是,继续移除问文件,将MusicTimer.rc资源文件移除。重新编译

6cf24898beeaaa3bad3843a75ef374be.png

问题没有了。反复重新生成,都没有问题。但是新的问题是,软件还需要图标(生成的EXE没有自定义图标),没有rc文件怎么行。直接使用Qt的setWindowIcon()还实现不了这个功能。

资源文件内容如下,很简单的内容。

1af3c57d9da400b96cdbb2665101d2bf.png

经过反复的添加和移除MusicTimer.rc文件,问题和上述一样。

在反复调试,运行过程中发现一个新的错误问题

cf4028c1d87c1a24f6721c5ee551be22.png

目前猜测和这个有很大关系,但还不敢确定。后续再找时间继续查找解决方法。

Logo

鸿蒙生态一站式服务平台。

更多推荐