qtcreator相对路径格式

qtcreator相对路径格式,第1张

pro文件里的相对路径不全都是相对于pro文件的,有的是,有的不是。

1、一种情况下./表示.pro文件所在的目录;另一种情况下./表示构建生成目昌液录;

1.1.是的情况

SOURCE

FORMS

HEADERS

INCLUDEPATH

DEPENDPATH 等等

这些变量中使用的./指的是.pro文件所在的目录

1.2.不是的情况

DESTDIR

OBJECTS_DIR

MOC_DIR

RCC_DIR

UI_DIR

UI_HEADERS_DIR

UI_SOURCES_DIR

win32:CONFIG(debug)

win32:CONFIG(release) 等等

这些变量中使用的./指的是构建生成目录。

2、影子构造说明

如果没有选择影子构造(shadow build),构建生成目录和.pro文件所在目录是同一个目录;

如果指定了shadow build,且指定了构建生成目录,那构建目录和.pro文件所在目录就不是同一个。

我们默认是会选择shadow build的,所以构建目录≠.pro目录。

3、subdirs:多工程多目录的情况

它们的相对路径都是针对你项目下的构建目录+子项目文件夹来的,例如

TEMPLATE = subdirs

SUBDIRS = \

muparser \

librecad

CONFIG += order

那么构建目录,BuildPath假如是F:\CADCAM\QCAD\src\build-LibreCAD-v1.0.4-qt4-Desktop_Qt_4_8_7_MSVC2010_32bit-Debug

于是,相对路径和绝对路径的对应关系,分别是:

---举简世例1---

相对,DESTDIR = bin

绝对,DESTDIR =$${BuildPath}/muparser/bin

绝对,DESTDIR =$${BuildPath}/librecad/bin

---举例2---

相对,DESTDIR = ../bin

绝对,$${BuildPath}/bin

4、.pro文件打印输出

在.pro文件,添加message函数,保存,会在“编译输出”窗口,打印出结果。

message($$PROJECT_ROOT)

message($$PWD)

message($$DESTDIR)

message($$TARGET)

Project MESSAGE: F:/CADCAM/QCAD/src/LibreCAD-v1.0.4-qt4/muparser

Project MESSAGE: F:/CADCAM/QCAD/src/LibreCAD-v1.0.4-qt4/muparser

Project MESSAGE: ../bin/lib

Project MESSAGE: muparserd

5、.pro常用的宏定义

TEMPLATE = app

HEADERS:需要包含的头文件的列表。

SOURCES:需要的源文件的列表。

FORMS:需要的.ui文件的列表。

LEXSOURCES:所有lex源文件的列表。

YACCSOURCES:所耐咐物有yacc源文件的列表。

TARGET:可执行应用程序的名称。默认值为项目文件的名字。

DESTDIR:放置可执行程序目标的目录。

OBJECTS_DIR:放置obj中间文件的目录。

MOC_DIR: moc转换文件路径。

RCC_DIR: 资源文件路径。

UI_DIR:ui文件转换的路径。

RESOURCES:需要包含的资源文件。

LIBS:依赖库的路径和名称 -L{xxdirxx} -l{xxnamexx}。

LIBEXT: 产生lib的后缀。

DEFINES:应用程序所需的额外的宏定义列表。

INCLUDEPATH:应用程序所需的额外的包含路径列表。

DEPENDPATH:应用程序所依赖的搜索路径。

VPATH:寻找补充文件的搜索路径。

DEF_FILE:只有Windows需要:应用程序所要连接的.def文件。

RC_FILE:只有Windows需要:应用程序的资源文件。

RES_FILE:只有Windows需要:应用程序所要连接的资源文件。

TRANSLATIONS: 多国语言支持文件。

INSTALLS: 要安装的文件。

target.path: 安装的路径。

如果在使用QtCreator编译项目时出现找不到qt5core.so的情况,可以尝试以下步骤:

确认Qt5已经正确安装。可以在终端输入以下命令来检查:

plaintext

Copy code

qmake -v

如果输出类似下面的信息,表示Qt5已经正确安装:

plaintext

Copy code

QMake version 3.1

Using Qt version 5.15.2 in /usr/lib/x86_64-linux-gnu

确认Qt5的库文件路键肢径已经添加到LD_LIBRARY_PATH环境变量中。可以在终端输入以下命令来检查:

plaintext

Copy code

echo $LD_LIBRARY_PATH

如果输出为空或者没有包含Qt5的库文件路径,可以手动添加。比如,在Ubuntu系统中,可以在~/.bashrc文件中添加以下内容:

plaintext

Copy code

export LD_LIBRARY_PATH=/usr/lib/x86_64-linux-gnu/qt5/lib/:$LD_LIBRARY_PATH

在QtCreator中确认编译选项是否正确。可以在QtCreator中打开项目的.pro文件,找到以下语句:

plaintext

Copy code

QT += core

确认是否者升包含了需要的Qt模块。如果需要使用其他模块,可以添加到这个语句中。

4. 在QtCreator中确认Qt5的路径是否正确。可以在QtCreator的菜单中选择工具->选项->构建和运行->Qt版本,确认Qt5的安装路径是否正确。

通过以上步骤,应该可稿嫌世以解决找不到qt5core.so的问题。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12282424.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存