【Qt】 Pro工程管理文件介绍

一般在新建一个工程后,在目录中都有一个*.pro的文件,这个文件名称与项目名称相同,我们称之为工程管理文件。该文件主要实现工程的相关配置,例如工程中包含的组件,文件,链接库等。qmake使用.pro文件生成Makefile。

现在看一下我们以前新建的test工程目录,其中test.pro就是工程管理文件。

Qt编译项目时,首先时qmake根据pro文件生成相应的makefile文件,然后再通过make命令编译项目。工程新建时pro文件并不是空的,里面会包含一些基础信息。在后续的开发中,Qt会自动修改pro文件内容,有时我们也会手动添加一些配置。

1.配置信息构成

双击test.pro文件,我们可以看到如下内容:

QT       += core gui

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

TARGET = test
TEMPLATE = app

# The following define makes your compiler emit warnings if you use
# any feature of Qt which has been marked as deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if you use deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

CONFIG += c++11

SOURCES += \
        main.cpp \
        mainwindow.cpp

HEADERS += \
        mainwindow.h

FORMS += \
        mainwindow.ui

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

#开头的行为注释,其余部分为配置信息。

配置信息由三部分,左侧为配置项,中间是操作符(+=,-=,=),右侧为值。

2.常用配置信息

QT

指定项目中用到的所有模块,默认值为 core 和 gui,中间用 += 符号连接。

例如

QT += core gui

如果想建立一个不包含Qt GUI模块的项目,可以使用“ -=”操作符。

例如

QT -= gui

TARGET

指定目标生成的名称。默认值为项目名。

例如

TARGET = test

TEMPLATE

指定生成makefile的类型。

可供使用的选项如下:

app:创建一个用于构建应用程序的Makefile(默认)。
lib:创建一个用于构建库的Makefile。
subdir: 创建一个用于构建目标子目录的Makefile,子目录使用SUBDIRS变量指定。
aux:创建一个不建任何东西的Makefile。如果没有编译器需要被调用来创建目标,比如你的项目使用解释型语言写的,使用此功能。注:此模板类型只能用于Makefile-based生成器。特别是,它不会工作在vcxproj和Xcode生成器。
vcapp:仅适用于Windows。创建一个Visual Studio应用程序项目。
vclib:仅适用于Windows。创建一个Visual Studio库项目。

例如:

TEMPLATE = app

DEFINES

在程序中新定义一个指定的宏,比如 DEFINES += xxx,如同在程序中添加了 #define xxx 语句。

例如:

DEFINES += QT_DEPRECATED_WARNINGS

CONFIG

指定编译器选项和项目配置,值由qmake内部识别并具有特殊意义。

以下配置值控制编译标志:

release:项目以release模式构建。如果也指定了debug,那么最后一个生效。
debug:项目以debug模式构建。
debug_and_release:项目准备以debug和release两种模式构建。
debug_and_release_target:此选项默认设置。如果也指定了debug_and_release,最终的debug和release构建在不同的目录。
build_all:如果指定了debug_and_release,默认情况下,该项目会构建为debug和release模式。
autogen_precompile_source:自动生成一个.cpp文件,包含在.pro中指定的预编译头文件。
ordered:使用subdirs模板时,此选项指定应该按照目录列表的顺序处理它们。
precompile_header:可以在项目中使用预编译头文件的支持。
warn_on:编译器应该输出尽可能多的警告。如果也指定了warn_off,最后一个生效。
warn_off :编译器应该输出尽可能少的警告。
exceptions:启用异常支持。默认设置。
exceptions_off :禁用异常支持。
rtti :启用RTTI支持。默认情况下,使用编译器默认。
rtti_off:禁用RTTI支持。默认情况下,使用编译器默认。
stl:启用STL支持。默认情况下,使用编译器默认。
stl_off:禁用STL支持。默认情况下,使用编译器默认。
thread:启用线程支持。当CONFIG包括qt时启用,这是缺省设置。
c++11:启用c++11支持。如果编译器不支持c++11这个选项,没有影响。默认情况下,支持是禁用的。
c++14:启用c++14支持。如果编译器不支持c++14这个选项,没有影响。默认情况下,支持是禁用的。

例如:

CONFIG += c++11

SOURCES

指定项目中包含的所有 .cpp 源文件

例如:

SOURCES += \

        main.cpp \

        mainwindow.cpp

HEADERS

指定项目中包含的所有 .h 源文件

例如:

HEADERS += mainwindow.h

FORMS

指定项目中包含的所有 .ui 源文件

例如:

FORMS += mainwindow.ui

INCLUDEPATH

指定头文件的存储路径。

例如:

INCLUDEPATH +=D:\OpenCV2.0\vc2008\include\opencv

LIBS

添加动态库。

例如:

LIBS += D:\OpenCV2.0\vc2008\lib\cv200.lib
LIBS += D:\OpenCV2.0\vc2008\lib\cv200d.lib
LIBS +=D:\OpenCV2.0\vc2008\lib\cxcore200.lib
LIBS += D:\OpenCV2.0\vc2008\lib\cxcore200d.lib
LIBS += D:\OpenCV2.0\vc2008\lib\ml200.lib
LIBS += D:\OpenCV2.0\vc2008\lib\ml200d.lib
LIBS +=D:\OpenCV2.0\vc2008\lib\cvaux200.lib
LIBS +=D:\OpenCV2.0\vc2008\lib\cvaux200d.lib
LIBS += D:\OpenCV2.0\vc2008\lib\highgui200.lib
LIBS +=D:\OpenCV2.0\vc2008\lib\highgui200d.lib
LIBS += D:\OpenCV2.0\vc2008\lib\cxts200.lib
LIBS +=D:\OpenCV2.0\vc2008\lib\cxts200d.lib

3.总结

通过上面的学习我们基本可以掌握pro文件的一些写法,希望对大家有所帮助。

 

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值