baizy77 发表于 2018-9-23 16:58:09

【独家连载】Qt入门与提高:K02-01通过简单exe介绍pro基本配置

本帖最后由 baizy77 于 2019-8-23 16:49 编辑

版权声明---------------------------------------------------------------------------------------------------------------------该文章原创于Qter开源社区(www.qter.org)作者: 女儿叫老白转载请注明出处!---------------------------------------------------------------------------------------------------------------------课程目录: 【独家连载】《Qt入门与提高-GUI产品开发》目录
网页版课程源码 提取码:1uy7
引言----------------------------------------------------------------从本节开始,我们将跟大家一起学习Qt。我们从基础知识开始,逐步为读者介绍Qt界面开发的常用技能,带领读者走进Qt的开发世界。
正文----------------------------------------------------------------本节,我们通过一个简单的exe介绍pro文件的基本配置。    我们的exe功能很简单,仅输出一行信息: 我真的啥也没干。
代码清单02-01-01main.cpp#include <iostream>
#include "qglobal.h"

using std::cout;
using std::endl;
int main(int argc, char * argv[])
{
Q_UNUSED(argc);
Q_UNUSED(argv);

cout << "我真的啥也没干." << endl;
return 0;
}
    在代码清单02-01-01中,为了向终端输出日志,需要用到cout,行尾的endl表示换行。这需要引用<iostream>,所以我们编写了第1行的include语句。    这是C++的写法,在C中使用“iostream.h”。
大家可能注意到了,在第4~5行代码,我们使用using语句引入了cout和endl。这是因为我们不想引入整个stl命名空间,有的coder可能会使用如下代码:using namespace stl; // 不推荐    但我们不推荐这样做。我们推荐仅引入所需的内容,或者不编写引入命名空间的代码,而是直接在使用cout时写成:   std::cout << “xxx” << std::endl;    main()函数比较简单,无需过多讲解。我们来看一下怎么编译这个文件。在C++中,如果使用gcc编译 器,那么我们需要提供Makefile文件(项目文件),而这个文件使用手工编写是非常麻烦的,而且还涉及到非常多非常复杂的编译选项。Qt提供了一种简化手段来提供这个Makefile文件,它要求开发者提供pro文件,然后使用qmake命令将其转换为Makefile。那么pro文件是什么呢?    pro文件是一个文本文件,它采用key = values的语法。比如,我们这个工程用到了main.cpp,那么我们可以在pro中编写如下语句:   
SOURCES +=main.cpp其中,SOURCES指明本项目用到的cpp文件列表。其中+=表示在SOURCES原值的基础上添加main.cpp。比如,我们在pro后面的部分可以继续追加cpp文件:SOURCES +=main.cpp

SOURCES += imp.cpp
这样项目包含的cpp文件(SOURCES)就变成:main.cpp、imp.cpp。
    如果有多个cpp文件,我们可以写在main.cpp的后面:SOURCES += main.cppimp.cpp但是,这样可读性不是很好,我们一般会使用“\”进行换行,比如:SOURCES += main.cpp \
                   imp.cpp
    请注意main.cpp和“\”之间最好加一个空格以便增加可读性。
    如果向项目中添加头文件,我们可以使用HEADERS配置项,用法同SOURCES。比如:HEADERS+= myclass.h \
               imp.h
    为了指明本项目的目标程序名称,我们用到TARGET配置项:TARGET   = ks02_01    这行代码表明我们的项目最终程序为ks02_01,如果它是一个可执行程序,那么最终在windows上生成的程序为ks02_01.exe,在linux上(或unix)上为ks02_01。如果生成的是一个dll,那么在windows上为ks02_01.dll,在 linux(或unix)上可能为libks02_01.so.1.0.0。    以上介绍了pro文件最最基本的配置。我们看一下pro文件的完整内容:
代码清单02-01-02ks02_01.proTEMPLATE         = app
LANGUAGE         = C++
CONFIG            += console
TARGET       = ks02_01
HEADERS            += ks02_01.pro         
SOURCES   +=main.cpp
DESTDIR          = ../../../bin
OBJECTS_DIR= ../../../obj/chapter02/ks02_01
MOC_DIR             = ../../../obj/moc/chapter02/ks02_01
    在代码清单02-01-02中,TEMPLATE = app表示这是一个exe项目。如果是dll,则TEMPLATE=lib。    因为使用C++语言进行开发,所以配置为:LANGUAGE = C++。    我们这个项目是一个终端运行程序(命令行程序),所以设置为:CONFIG += console,如果不设置,则无法在终端中正常运行(比如,cout的信息无法输出到终端)。读者可以封掉这行配置进行验证,方法是在改行配置前加上一个"#"号(请使用英文、半角,不要用中文输入),"#"的作用表示本行为注释,那么Qt就不会把这行当作配置进行解析。    最后的几个DIR用来设置各种文件的路径。    DESTDIR:表示最终目标程序的存放路径。       OBJECTS_DIR:表示程序生成的中间临时文件的存放路径。     MOC_DIR:用来设置moc文件的存放路径(Qt的moc命令生成的临时文件)。该配置项我们后面章节中会详细说明。大家可能注意到了,在本节的pro中这些路径的设置都使用了相对路径的方式。其实我们并不推荐这种方式,在后面的章节中我们会使用环境变量的方式设置这些路径。现在把pro文件和cpp文件放到同一个目录下,目录名为ks02_01。然后在VS2017的64位命令行下,进入项目所在目录,执行:
qmake
nmake
程序即可编译成功。如果您希望使用VS2017的IDE开发环境打开该项目,那么需要生成VS2017可以识别的项目文件,方法是在VS2017的64位命令行中,进入项目所在目录,运行:qmake-tpvc这样就可以得到名为ks02_01.vcxproj的项目文件,该文件可以被VS2017识别。好了,pro介绍完毕,大家可以尝试一把了。
结语----------------------------------------------------------------
本文介绍了pro最基本的配置项,目的是让大家能够开始编写自己的第一个Qt程序。后面我们会为读者介绍更多在产品开发中用到的的Qt知识。



下一节:KS02-02   整理一下目录吧
页: [1]
查看完整版本: 【独家连载】Qt入门与提高:K02-01通过简单exe介绍pro基本配置