QT中PRO文件写法的详细介绍,很有用,很重要!

本文介绍如何使用.qpro文件配置QT项目,包括指定生成的应用程序名称、配置信息、文件路径等,并提供了一个详细的.qpro文件示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在QT中,有一个工具qmake可以生成一个makefile文件,它是由.pro文件生成而来的,.pro文件的写法如下:


1. 注释
从“#”开始,到这一行结束。

2.模板变量告诉qmake为这个应用程序生成哪种makefile。下面是可供使用的选择:
TEMPLATE = app
A> app -建立一个应用程序的makefile。这是默认值,所以如果模板没有被指定,这个将被使用。
B> lib - 建立一个库的makefile。
C> vcapp - 建立一个应用程序的VisualStudio项目文件。
D> vclib - 建立一个库的VisualStudio项目文件。
E> subdirs -这是一个特殊的模板,它可以创建一个能够进入特定目录并且为一个项目文件生成makefile并且为它调用make的makefile。


#指定生成的应用程序放置的目录
DESTDIR += ../bin

#指定生成的应用程序名
TARGET = pksystem

#配置信息
CONFIG用来告诉qmake关于应用程序的配置信息。

    CONFIG+= qt warn_on release

在这里使用“+=”,是因为我们添加我们的配置选项到任何一个已经存在中。这样做比使用“=”那样替换已经指定的所有选项是更安全的。
A> qt部分告诉qmake这个应用程序是使用Qt来连编的。这也就是说qmake在连接和为编译添加所需的包含路径的时候会考虑到Qt库的。
B> warn_on部分告诉qmake要把编译器设置为输出警告信息的。
C> release部分告诉qmake应用程序必须被连编为一个发布的应用程序。在开发过程中,程序员也可以使用debug来替换release


#指定uic命令将.ui文件转化成ui_*.h文件的存放的目录
UI_DIR += forms

#指定rcc命令将.qrc文件转换成qrc_*.h文件的存放目录
RCC_DIR += ../tmp

#指定moc命令将含Q_OBJECT的头文件转换成标准.h文件的存放目录
MOC_DIR += ../tmp

#指定目标文件(obj)的存放目录
OBJECTS_DIR += ../tmp

#程序编译时依赖的相关路径
DEPENDPATH += . forms include qrc sources

#头文件包含路径
INCLUDEPATH += .

#qmake时产生的信息,【$${a}读取变量a的字符串】,【$$(PATH)读取环境变量PATH】
#message($$(PATH))

#源文件编码方式
CODECFORSRC = GBK

#工程中包含的头文件
HEADERS += include/painter.h
#工程中包含的.ui设计文件
FORMS += forms/painter.ui
#工程中包含的源文件
SOURCES += sources/main.cpp sources/painter.cpp
#工程中包含的资源文件
RESOURCES += qrc/painter.qrc

 

LIBS += -L folderPath  //引入的lib文件的路径  -L:引入路径

Release:LIBS += -L folderPath // release 版引入的lib文件路径

Debug:LIBS += -L folderPath // Debug 版引入的lib 文件路径

DEFINES += XX_XX_XXX  //定义编译选项,在.h文件中就可以使用 :#ifdefine xx_xx_xxx

RC_FILE = xxx.icns

7. 平台相关性处理
我们在这里需要做的是根据qmake所运行的平台来使用相应的作用域来进行处理。为Windows平台添加的依赖平台的文件的简单的作用域看起来就像这样:

win32 {
SOURCES += hello_win.cpp
}
====================================================================================================================
当你已经创建好你的项目文件,生成Makefile就很容易了,你所要做的就是先到你所生成的项目文件那里然后输入:

Makefile可以像这样由“.pro”文件生成:

    qmake -oMakefile hello.pro

对于VisualStudio的用户,qmake也可以生成“.dsp”文件,例如:

    qmake -tvcapp -o hello.dsp hello.pro

 

++++++++++++++++++++++++一个PRO文件实例++++++++++++++++++++++++++++++++++++++++

TEMPLATE = app     #模块配置
LANGUAGE = C++   #C++语言

CONFIG += qt warn_on debug release

#引入的lib文件,用于引入动态链接库
LIBS += qaxcontainer.lib

#头文件包含路径
INCLUDEPATH += ../../qtcompnent/qtchklisten/inc ../../qtcompnent/qtclearfile/inc ../../validator/inc/validerrcode ../../qtcompnent/qtdir/inc ../inc ../../utillib/inc/xmlapi ../../utillib/inc/util ../../xercesc ../../qtcompnent/qteditor/inc ../../qtcompnent/qtfunreview/inc ../../qtcompnent/qttable/inc ../../qtcompnent/qtversion/inc ../../qtcompnent/qtini/inc ../../icdtool/icdservices/inc ../../icdtool/dataset/inc ../../icdtool/doi/inc ../../icdtool/reportcontrol/inc ../../icdtool/GSEconctrol/inc ../../icdtool/inputs/inc ../../icdtool/SMVconctrol/inc ../../icdtool/logcontrol/inc ../../scdpreview/inc/scdpreviewtoollib ../../scdpreview/form ../../icdtool/sclcontrol/inc ../../icdtool/log/inc ../../icdtool/settingcontrol/inc ../../qtcompnent/qteditor/inc ../../qtcompnent/qttreeview/inc ../../qtcompnent/qttabwidget/inc ../../communication/inc ../../qtcompnent/qtabout/inc ../iedmanage/inc ../ldmanage/inc ../foriecrun/inc ../../qtcompnent/validset/inc

#工程中包含的头文件
HEADERS += ../inc/exportstable.h /
 ../inc/maintabwidget.h /
 ../inc/outputtab.h /
 ../inc/strutil.h /
 ../inc/treeeditview.h /
 ../inc/MainForm.h /
 ../inc/recenfileini.h /
 ../inc/ExportCIDFunction.h

#工程中包含的源文件
SOURCES += ../src/main.cpp /
 ../src/exportstable.cpp /
 ../src/maintabwidget.cpp /
 ../src/outputtab.cpp /
 ../src/treeeditview.cpp /
 ../src/MainForm.cpp /
 ../src/recenfileini.cpp /
 ../src/ExportCIDFunction.cpp

#工程中包含的.ui设计文件
FORMS = ../form/scdmainform.ui /
 ../form/exportiedform.ui /
 ../form/Exportsedform.ui /
 ../form/Importsedform.ui /
 ../form/formiminputs.ui

#图像文件

IMAGES = images/substation.png /
 images/communication.png /
 images/autocom.png /
 images/reportcfg.png /
 images/comcfg.png /
 images/filetrans.png /
 images/review.png /
 images/setting.png

#工程中包含的资源文件
RESOURCES   = Scintilla.qrc

#CONFIG -= release
CONFIG -= debug


RC_FILE = scdtool.rc

 
BINLIB = ../../bin ../../xercesc/lib

UI_HEADERS_DIR = ../inc  # .ui文件转会为**.h   存放的目录
UI_SOURCES_DIR = ../src  # .ui文件转会为**.cpp 存放的目录
QMAKE_LIBDIR = $${BINLIB}

release {
TARGET = scdtool       #指定生成的应用程序名
OBJECTS_DIR = ../../obj/scdtool/release #指定目标文件(obj)的存放目录
}
debug {
TARGET = scdtool_d     #指定生成的应用程序名
OBJECTS_DIR = ../../obj/scdtool/debug #指定目标文件(obj)的存放目录
}

MOC_DIR = $${OBJECTS_DIR}
DESTDIR = ../../bin    #指定生成的应用程序放置的目录

 

 

<think>好的,我现在需要解决用户的问题:QT打开项目时找不到main函数文件的原因及解决方案。首先,我得回顾一下用户提供的引用内容,看看有没有相关的信息。 用户引用了四个资料。引用1是关于QT连接SQLite数据库的问题,可能和当前问题无关。引用2提到了Qt项目的结构,包括main.cpp作为应用入口,这可能有用。引用3和4都涉及main函数的存在和配置,特别是引用3展示了如何在main函数中初始化MainWindow,而引用4讨论了一个解决方案中多个项目或多个main函数的情况,以及如何排除其他main函数。 接下来,我需要分析可能的原因。首先,项目结构问题,比如main.cpp文件是否被正确包含在项目中。其次,构建系统配置错误,比如CMakeLists.txt或.pro文件没有正确包含main.cpp。还有可能是多个main函数冲突,或者代码错误导致main函数未被正确识别。另外,用户可能错误地排除了main.cpp文件,或者在IDE配置中没有正确设置启动项。 解决方案方面,应该逐步检查项目结构,确认main.cpp是否存在并正确添加。检查构建系统的配置文件,确保main.cpp被包含。处理多个main函数的情况,排除多余的main函数。检查代码语法错误,确保main函数正确。同时,检查IDE的配置,比如启动项目设置是否正确,或者是否清理了旧构建缓存。 需要确保回答结构清晰,分点列出原因和对应的解决方法,并引用用户提供的资料中的相关内容。例如,引用2提到了main.cpp作为入口文件,引用3和4讨论了main函数的配置和排除方法。在解决方案中需要结合这些信息,指导用户逐步排查问题。</think>### QT项目找不到main函数文件的原因及解决方案 #### 一、常见原因分析 1. **项目结构配置错误** - CMakeLists.txt或.pro文件未正确包含main.cpp,导致构建系统未识别入口文件[^2] - 项目目录中main.cpp文件物理丢失或被误删除 2. **多main函数冲突** - 解决方案中存在多个项目时,未正确设置启动项[^4] - 同一项目中有多个包含main函数的文件(如测试文件、旧代码残留) 3. **IDE配置问题** - Qt Creator未正确加载项目文件,导致文件树显示不全 - 构建缓存未清理,残留错误配置[^3] #### 二、解决方法步骤 **1. 验证文件存在性** 通过文件管理器手动检查项目目录是否存在main.cpp文件: ``` 项目根目录/ ├── CMakeLists.txt ├── main.cpp <-- 确认此文件存在 └── src/ ``` **2. 检查构建配置** - **对于qmake项目**:检查.pro文件是否包含: ```makefile SOURCES += main.cpp ``` - **对于CMake项目**:检查CMakeLists.txt是否包含: ```cmake add_executable(FirstQt5 main.cpp mainwindow.cpp) # 需包含main.cpp[^2] ``` **3. 处理多main函数问题** - 在Qt Creator中右击其他项目的main文件 → 选择"从项目中排除" - 使用条件编译控制多个main函数: ```cpp // #define TEST_MODE #ifndef TEST_MODE int main(int argc, char *argv[]) { QApplication a(argc, argv); MainWindow w; w.show(); return a.exec(); } #endif ``` **4. 重建项目缓存** 执行以下操作清除旧配置: ```bash # 删除构建目录 rm -rf build/ # Qt Creator菜单操作 构建 → 重新构建项目 工具 → 清除构建目录 ``` **5. 检查启动项设置** 在Qt Creator左下角: 1. 选择"项目"模式 2. 确认当前构建套件对应正确项目 3. 检查"构建步骤"中的源文件列表 #### 三、典型错误案例 **错误现象**:使用全局变量传递窗口指针导致main函数未正确初始化[^3] ```cpp // 错误示例:全局指针未初始化 MainWindow *pw; // 应改为 MainWindow *pw = nullptr; int main() { MainWindow w; pw = &w; // 此处可能引发空指针问题 } ``` **正确写法**: ```cpp MainWindow *pw = nullptr; int main(int argc, char *argv[]) { QApplication a(argc, argv); MainWindow w; pw = &w; // 正确初始化 w.show(); return a.exec(); } ```
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值