目录

  • 1、问题描述
  • 2、方案
  • 3、分析
  • 4、总结


1、问题描述

无法解析的外部符号 __imp_JNI_CreateJavaVM 无法解析的外部符号public_Qt


[注]CheckBoxHeaderView是我自己的类名

由于项目需要,要将QT类添加到VS对应工程中,通过项目右键添加该类的.h和.cpp文件,生成dll时候一直报错,无法解析的外部符号"public: virtual struct QMetaObject const …"
一般来说,出现无法解析的外部符号时,有两种情况:

  1. 函数定义:.h/.cpp所提供的函数接口版本、重定义或未注册等情况。
  2. 函数接口:.lib文件所提供的函数接口在.sln解决方案中不存在。

以上两种情况可以通过修改VS配置、添加文件进行改正。

2、方案

方案1:根据关键字QMetaObject,定位到可能是QMetaType未注册,

  1. 添加对应头文件QMetaType
  2. 在构造函数中加入代码:qRegisterMetaType(“Myclass”);

还是报错:qt 没有合适的默认构造函数可用
这一般是ui中的objectName不对应,而我是通过项目添加.h/.cpp文件,并没有改ui,所以不是自定义类型未注册问题。

方案2:因为我的类型用到信号,而新加的信号使用时未重新生成,导致找不到该信号。

  1. 如果没有使用到信号和槽,可以去掉Q_OBJECT宏;
  2. 如果要用到信号和槽,添加Q_OBJECT,并重新make一下项目

方案2成功解决!

3、分析

由于通过Qt编程时,.h/.cpp文件并第一次编译之后,若.h文件中定义类时没有添加Q_OBJECT宏以及信号函数、槽函数,VS编译命令中就没有moc命令,就不会调用Qt的moc工具以生成moc_*.cpp文件;并且即使添加了Q_OBJECT宏之后,VS也不会自动添加moc命令,因而不会生成moc文件。
VS在LINK时,找不到moc文件,就出现了error LNK2001的错误。

4、总结

虽然只是重新make一下这个小事情,但是通过分析可以看出QT和VS编程生成过程的差别,移植代码需要注意;然后是养成代码文件添加删除后重新cmake的好习惯。