news 2026/5/30 20:20:19

Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码

文章目录

  • Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码
    • 0 背景
    • 1 实践
    • 2 扩展
    • 附录

Qt优雅的组织项目结构三(使用CMakeLists进行模块化配置)——————附带详细示例代码

0 背景

之前写过使用.cmake来进行项目的分模块化管理,但是发现分层后的项目结构并不是十分清晰,不同模块的代码还是混在了一起,而不是每个模块的代码都单独分离出来。子模块还是公用着主模块的构建配置。

使用.cmake前:

使用.cmake后:

因此这里使用CmakeLists.txt来对项目进行分模块化管理。可以将子项目完全独立管理,每个子项目可以有自己的构建配置

使用子模块CMakeLists.txt前:

使用子模块CMakeLists.txt后:


可以看到子模块的代码被完全分离出来,更方便进行管理。

1 实践

  • 1,创建项目;


  • 2,修改CMakeLists.txt的内容为;
# 设置cmake的最低版本cmake_minimum_required(VERSION3.16)# 定义项目名称、项目版本、变成语言project(TestCMakeLists VERSION0.1LANGUAGES CXX)# 自动处理界面文件set(CMAKE_AUTOUIC ON)# 自动处理信号与槽set(CMAKE_AUTOMOC ON)# 自动处理资源文件set(CMAKE_AUTORCC ON)# 指定 C++语言标准版本为C++17set(CMAKE_CXX_STANDARD17)# 强制要求指定的标准必须被满足。如果不支持C++17,CMake 配置阶段会直接报错并终止,不会尝试降级编译set(CMAKE_CXX_STANDARD_REQUIRED ON)# 保证代码的跨平台可移植性。 禁止编译器使用 GNU 扩展(如 GCC 的 gnu++17)或其他非标准的编译器扩展,强制使用严格的 ISO C++标准(即 c++17)。set(CMAKE_CXX_EXTENSIONS OFF)# 寻找Qt版本,并精确加载具体的 Qt 版本配置。find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets)find_package(Qt${QT_VERSION_MAJOR}REQUIRED COMPONENTS Widgets)set(PROJECT_NAME"TestCMakeLists")set(PROJECT_SOURCES main.cpp)# 调用编译器(如 `g++,cl.exe`)将源代码编译成目标文件`(.o 或.obj)`, # 然后调用链接器将这些目标文件和依赖库链接成一个完整的、操作系统可以直接加载的二进制文件`exe`add_executable(${PROJECT_NAME}${PROJECT_SOURCES})# 把库链接到目标执行程序上target_link_libraries(${PROJECT_NAME}PRIVATE Qt${QT_VERSION_MAJOR}::Widgets)# 为构建目标设置特定的属性(发布专业、规范的软件时,必不可少)set_target_properties(${PROJECT_NAME}PROPERTIES WIN32_EXECUTABLE TRUE)

把main函数修改为:

// #include "mainwindow.h"#include<QApplication>intmain(intargc,char*argv[]){QApplicationa(argc,argv);// MainWindow w;// w.show();returna.exec();}
  • 3,新建form文件夹,把UI相关的文件移到文件夹中;
  • 4,在form文件中,新建CMakeLists.txt文件,然后在根目录的CMakeLists.txt中添加如下内容,并重新构建;

放到add_executable之前:

# 将子项目作为独立模块管理add_subdirectory(Form)

修改后的文件为:

# 设置cmake的最低版本cmake_minimum_required(VERSION3.16)# 定义项目名称、项目版本、变成语言project(TestCMakeLists VERSION0.1LANGUAGES CXX)# 自动处理界面文件set(CMAKE_AUTOUIC ON)# 自动处理信号与槽set(CMAKE_AUTOMOC ON)# 自动处理资源文件set(CMAKE_AUTORCC ON)# 指定 C++语言标准版本为C++17set(CMAKE_CXX_STANDARD17)# 强制要求指定的标准必须被满足。如果不支持C++17,CMake 配置阶段会直接报错并终止,不会尝试降级编译set(CMAKE_CXX_STANDARD_REQUIRED ON)# 保证代码的跨平台可移植性。 禁止编译器使用 GNU 扩展(如 GCC 的 gnu++17)或其他非标准的编译器扩展,强制使用严格的 ISO C++标准(即 c++17)。set(CMAKE_CXX_EXTENSIONS OFF)# 寻找Qt版本,并精确加载具体的 Qt 版本配置。find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets)find_package(Qt${QT_VERSION_MAJOR}REQUIRED COMPONENTS Widgets)set(PROJECT_NAME"TestCMakeLists")set(PROJECT_SOURCES main.cpp)# (新添加内容)将子项目作为独立模块管理add_subdirectory(Form)# 调用编译器(如 `g++,cl.exe`)将源代码编译成目标文件`(.o 或.obj)`, # 然后调用链接器将这些目标文件和依赖库链接成一个完整的、操作系统可以直接加载的二进制文件`exe`add_executable(${PROJECT_NAME}${PROJECT_SOURCES})# 把库链接到目标执行程序上target_link_libraries(${PROJECT_NAME}PRIVATE Qt${QT_VERSION_MAJOR}::Widgets)# 为构建目标设置特定的属性(发布专业、规范的软件时,必不可少)set_target_properties(${PROJECT_NAME}PROPERTIES WIN32_EXECUTABLE TRUE)

重写构建项目,得到新的项目结构:

  • 5,修改form文件夹中的CMakeLists.txt的内容为下面的内容,然后重新构建;
# 设置cmake的最低版本cmake_minimum_required(VERSION3.16)# 定义项目名称、项目版本、变成语言project(FORM VERSION0.1LANGUAGES CXX)# 自动处理界面文件set(CMAKE_AUTOUIC ON)# 自动处理信号与槽set(CMAKE_AUTOMOC ON)# 自动处理资源文件set(CMAKE_AUTORCC ON)set(PROJECT_NAME"FORM")# 设置源文件set(SOURCES mainwindow.cpp)# 设置头文件set(HEADERS mainwindow.h)# 设置UI文件set(FORMS mainwindow.ui)# 创建动态链接库add_library(${PROJECT_NAME}STATIC ${SOURCES}${HEADERS}${FORMS})set(FORM_INCLUDE_DIRS"form/")# 链接Qt库target_link_libraries(FORM PRIVATE Qt5::Widgets)# 设置库的包含目录target_include_directories(FORM PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})

  • 6 ,修改根目录下的CMakeLists.txt文件,然后更改main函数;

末尾添加如下内容:

# 把库链接到目标执行程序上target_link_libraries(${PROJECT_NAME}PRIVATE FORM)

修改后CMakeLists.txt文件为:

# 设置cmake的最低版本cmake_minimum_required(VERSION3.16)# 定义项目名称、项目版本、变成语言project(TestCMakeLists VERSION0.1LANGUAGES CXX)# 自动处理界面文件set(CMAKE_AUTOUIC ON)# 自动处理信号与槽set(CMAKE_AUTOMOC ON)# 自动处理资源文件set(CMAKE_AUTORCC ON)# 指定 C++语言标准版本为C++17set(CMAKE_CXX_STANDARD17)# 强制要求指定的标准必须被满足。如果不支持C++17,CMake 配置阶段会直接报错并终止,不会尝试降级编译set(CMAKE_CXX_STANDARD_REQUIRED ON)# 保证代码的跨平台可移植性。 禁止编译器使用 GNU 扩展(如 GCC 的 gnu++17)或其他非标准的编译器扩展,强制使用严格的 ISO C++标准(即 c++17)。set(CMAKE_CXX_EXTENSIONS OFF)# 寻找Qt版本,并精确加载具体的 Qt 版本配置。find_package(QT NAMES Qt6 Qt5 REQUIRED COMPONENTS Widgets)find_package(Qt${QT_VERSION_MAJOR}REQUIRED COMPONENTS Widgets)set(PROJECT_NAME"TestCMakeLists")set(PROJECT_SOURCES main.cpp)# 将子项目作为独立模块管理add_subdirectory(Form)# 调用编译器(如 `g++,cl.exe`)将源代码编译成目标文件`(.o 或.obj)`, # 然后调用链接器将这些目标文件和依赖库链接成一个完整的、操作系统可以直接加载的二进制文件`exe`add_executable(${PROJECT_NAME}${PROJECT_SOURCES})# 把库链接到目标执行程序上target_link_libraries(${PROJECT_NAME}PRIVATE FORM)target_link_libraries(${PROJECT_NAME}PRIVATE Qt${QT_VERSION_MAJOR}::Widgets)# 为构建目标设置特定的属性(发布专业、规范的软件时,必不可少)set_target_properties(${PROJECT_NAME}PROPERTIES WIN32_EXECUTABLE TRUE)

然后,修改main函数的代码为:

//#include "mainwindow.h" //这种方式也可以#include"form/mainwindow.h"#include<QApplication>intmain(intargc,char*argv[]){QApplicationa(argc,argv);MainWindow w;w.show();returna.exec();}

重新构建,运行代码即可。

2 扩展

名称链接
pri模块化管理代码链接
.cmake模块化管理代码链接
CMakeLists.txt模块化管理代码链接

附录

完整的项目代码见此。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 20:07:18

科技巨头的生态构建之路:技术底座、技术生态与应用生态的协同演进

科技巨头的生态构建之路&#xff1a;技术底座、技术生态与应用生态的协同演进在数字经济时代&#xff0c;科技巨头的竞争已从单一产品的较量转向生态系统建设的综合实力比拼。技术底座、技术生态和应用生态构成了现代科技企业的"三位一体"战略框架&#xff0c;这一框…

作者头像 李华
网站建设 2026/5/29 20:10:35

VIVO BootLoader解锁终极指南:一站式Fastboot工具完整教程

VIVO BootLoader解锁终极指南&#xff1a;一站式Fastboot工具完整教程 【免费下载链接】VIVO解锁自带BootLoader工具包 本仓库提供了一个专为VIVO手机设计的Fastboot工具包&#xff0c;用于解锁VIVO手机的BootLoader&#xff08;BL&#xff09;。该工具包适用于Windows操作系统…

作者头像 李华
网站建设 2026/5/29 20:19:44

如何用AIPs解决团队API设计混乱问题

如何用AIPs解决团队API设计混乱问题 【免费下载链接】google.aip.dev API Improvement Proposals. https://aip.dev/ 项目地址: https://gitcode.com/gh_mirrors/go/google.aip.dev 在快速发展的软件开发环境中&#xff0c;API设计规范已成为提升开发效率和保证团队协作…

作者头像 李华
网站建设 2026/5/29 20:31:09

卫浴品牌导航大揭秘:精准筛选+5大维度,采购不踩坑

卫浴品牌导航大揭秘&#xff1a;精准筛选5大维度&#xff0c;采购不踩坑卫浴空间作为家居生活的重要场景&#xff0c;其产品品质直接影响使用体验与长期维护成本。然而&#xff0c;面对市场上琳琅满目的卫浴品牌&#xff0c;消费者往往陷入"品牌多、选择难"的困境。本…

作者头像 李华
网站建设 2026/5/30 12:42:34

GLM-4模型评估:避开5个常见误区的终极指南

GLM-4模型评估&#xff1a;避开5个常见误区的终极指南 【免费下载链接】GLM-4 GLM-4 series: Open Multilingual Multimodal Chat LMs | 开源多语言多模态对话模型 项目地址: https://gitcode.com/gh_mirrors/gl/GLM-4 GLM-4模型评估是确保模型在实际应用中发挥最佳性能…

作者头像 李华
网站建设 2026/5/29 21:03:29

5、探究古希腊喜剧表演:从文本到视觉的多维解析

探究古希腊喜剧表演:从文本到视觉的多维解析 1. 古希腊喜剧的独特魅力 古希腊喜剧是一种独特的戏剧类型,它在古人眼中犹如当时社会的摄影记录,却又构建出复杂的意识形态形象。以米南德的戏剧为例,其剧情通常分为三个相互交织的层次。 - 现实层面 :呈现简单、刻板的城…

作者头像 李华