C/C++ IDE环境 (Qt Creator visual studio等) Cmake工程不显示头文件的解决方案

简介: C/C++ IDE环境 (Qt Creator visual studio等) Cmake工程不显示头文件的解决方案

方式一: add_executable

例如, 在 Qt Creator 中,使用 CMake 构建项目时,默认情况下头文件不会显示在项目浏览器中。要让头文件显示出来,你可以在 CMakeLists.txt 文件中添加相应的头文件。

以下是一个简单的示例,展示了如何将头文件添加到 CMakeLists.txt 中:

cmake_minimum_required(VERSION 3.5)
project(MyQtProject LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
find_package(Qt5 COMPONENTS Core Widgets REQUIRED)
# 添加源文件和头文件
set(SOURCE_FILES
    main.cpp
    mainwindow.cpp
)
set(HEADER_FILES
    mainwindow.h
)
# 如果有 UI 文件或资源文件,也可以在此处添加
set(UI_FILES
    mainwindow.ui
)
set(QRC_FILES
    resources.qrc
)
qt5_wrap_ui(UI_HEADERS ${UI_FILES})
qt5_add_resources(QRC_RESOURCES ${QRC_FILES})
add_executable(MyQtProject ${SOURCE_FILES} ${HEADER_FILES} ${UI_HEADERS} ${QRC_RESOURCES})
target_link_libraries(MyQtProject Qt5::Core Qt5::Widgets)

在这个示例中,我们首先定义了一个变量 HEADER_FILES,其中包含了我们想要在项目中显示的头文件。然后,在 add_executable() 函数中添加这些头文件,以便它们能够显示在 Qt Creator 的项目浏览器中。

同样,我们还可以添加 UI 文件和资源文件,这样它们也会出现在项目浏览器中。这是通过 qt5_wrap_ui()qt5_add_resources() 函数完成的。

遍历头文件

为了遍历 ${CMAKE_SOURCE_DIR}/include 目录下的所有头文件,你可以使用 file(GLOB_RECURSE ...) 命令将它们添加到一个变量中,而不是使用 set()。这里是一个例子:

file(GLOB_RECURSE HEADER_FILES "${CMAKE_SOURCE_DIR}/include/*.h")

这个命令会递归地遍历 ${CMAKE_SOURCE_DIR}/include 目录,并将所有找到的 .h 文件添加到 HEADER_FILES 变量中。之后,你可以像之前的回答中展示的那样,将 HEADER_FILES 添加到 add_executable() 函数中。

但是,需要注意的是,使用 GLOB_RECURSE 可能会导致一些问题,因为当你添加或删除头文件时,CMake 可能不会自动重新运行。在这种情况下,你需要手动重新运行 CMake 以更新项目。因此,在某些情况下,显式地列出所有的头文件可能是更好的做法。

构建原理

将头文件添加到可执行文件(add_executable())实际上并不会影响编译过程。头文件主要是为了在编译期间提供类型声明、函数原型和其他信息。编译器在处理源文件时,会通过源文件中的 #include 指令找到并处理这些头文件。

将头文件添加到 add_executable() 的主要目的是让这些头文件在某些集成开发环境(IDE)中(如 Qt Creator)显示出来。这样可以方便地在 IDE 中浏览和编辑头文件。但是,这并不会改变编译过程。

实际上,当你编译一个项目时,编译器只处理源文件(如 .cpp 文件)。这些源文件中的 #include 指令会让编译器去查找并处理相应的头文件。因此,即使你没有将头文件添加到 add_executable() 中,只要源文件正确地包含了这些头文件,它们仍然会在编译期间被处理。

注意

如果你已经使用 file()add_executable() 将头文件添加到了可执行文件,通常情况下,编译器仍然需要知道头文件的位置。这时你需要使用 include_directories() 或者 target_include_directories() 来指定头文件的路径。

这两个命令的区别在于:

  • include_directories(): 这个命令会将给定目录添加到所有目标的头文件搜索路径中。这意味着在项目中定义的所有目标都将使用这个路径来查找头文件。
  • target_include_directories(): 这个命令允许你为特定目标指定头文件搜索路径。这样,只有指定的目标会使用这个路径来查找头文件。

以下是一个使用 target_include_directories() 的例子:

cmake_minimum_required(VERSION 3.5)
project(MyProject LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
file(GLOB_RECURSE HEADER_FILES "${CMAKE_SOURCE_DIR}/include/*.h")
file(GLOB_RECURSE SOURCE_FILES "${CMAKE_SOURCE_DIR}/src/*.cpp")
add_executable(MyProject ${HEADER_FILES} ${SOURCE_FILES})
# 指定头文件搜索路径
target_include_directories(MyProject PRIVATE ${CMAKE_SOURCE_DIR}/include)

在这个例子中,我们使用 file()add_executable() 将头文件和源文件添加到了可执行文件。然后,我们使用 target_include_directories()MyProject 目标指定了头文件搜索路径,这样编译器就能找到这些头文件。这里使用了 PRIVATE 关键字,表示这个头文件路径仅对 MyProject 目标有效。

所以,即使你已经将头文件添加到了可执行文件,你仍然需要使用 include_directories()target_include_directories() 来指定头文件的位置。

方式二: source_group

将头文件添加到 add_executable() 是解决 IDE 环境中 CMake 项目不显示头文件的一种常用方法。但是,也有其他方法可以实现类似的效果,例如使用源文件组(source groups)。

源文件组允许你在 IDE 中对文件进行分组和分类。在 CMake 中,你可以使用 source_group() 命令来创建源文件组。以下是一个示例:

cmake_minimum_required(VERSION 3.5)
project(MyQtProject LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
find_package(Qt5 COMPONENTS Core Widgets REQUIRED)
# 添加源文件和头文件
set(SOURCE_FILES
    main.cpp
    mainwindow.cpp
)
set(HEADER_FILES
    mainwindow.h
)
# 创建源文件组
source_group(TREE "${CMAKE_CURRENT_SOURCE_DIR}" FILES ${SOURCE_FILES} ${HEADER_FILES})
# 如果有 UI 文件或资源文件,也可以在此处添加
set(UI_FILES
    mainwindow.ui
)
set(QRC_FILES
    resources.qrc
)
qt5_wrap_ui(UI_HEADERS ${UI_FILES})
qt5_add_resources(QRC_RESOURCES ${QRC_FILES})
add_executable(MyQtProject ${SOURCE_FILES} ${HEADER_FILES} ${UI_HEADERS} ${QRC_RESOURCES})
target_link_libraries(MyQtProject Qt5::Core Qt5::Widgets)

在这个示例中,我们使用 source_group() 命令创建了一个源文件组,将源文件和头文件分组到一起。TREE 参数表示我们希望从当前源文件目录开始组织文件。这将使得在 IDE(如 Qt Creator)中显示头文件成为可能。

然而,不同 IDE 对 CMake 的支持程度不同,因此这些方法在不同的 IDE 中可能会有所差异。总的来说,将头文件添加到 add_executable() 是一种更通用的方法。

结语

不管采用哪种方式,都不会影响编译过程。头文件主要是在编译时为源文件提供类型声明、函数原型和其他信息。头文件会在源文件中通过 #include 指令被包含,这些方法主要是为了在 IDE 中方便地显示和管理头文件。


目录
相关文章
|
6月前
|
C语言 C++
C/C++ 自定义头文件,及头文件结构详解
还是从"stdio.h"说起,这是C语言中内置的标准库,也就是说,头文件很多时候其实就是一个“库”,类似于代码的仓库,也就是说将某些具有特定功能的常量、宏、函数等归为一个大类,然后放进这个“仓库”,就像stdio.h就是一个标准输入/输出的头文件
204 1
|
6月前
|
C++
C++ 数学函数、头文件及布尔类型详解
C++ 支持数学操作,如`max`和`min`函数找最大值和最小值,以及`<cmath>`库中的`sqrt`、`round`等数学函数。`bool`类型用于布尔逻辑,取值`true`(1)或`false`(0)。布尔表达式结合比较运算符常用于条件判断,例如在`if`语句中检查年龄是否达到投票年龄。在代码示例中,`isCodingFun`和`isFishTasty`变量分别输出1和0。
180 1
|
6月前
|
开发框架 Unix Linux
深度探索:Qt CMake工程编译后的自动打包策略
深度探索:Qt CMake工程编译后的自动打包策略
351 0
|
21天前
|
自然语言处理 编译器 Linux
告别头文件,编译效率提升 42%!C++ Modules 实战解析 | 干货推荐
本文中,阿里云智能集团开发工程师李泽政以 Alinux 为操作环境,讲解模块相比传统头文件有哪些优势,并通过若干个例子,学习如何组织一个 C++ 模块工程并使用模块封装第三方库或是改造现有的项目。
|
1月前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
293 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
3月前
CMake自动打包--Qt项目
CMake自动打包--Qt项目
55 0
|
3月前
|
编译器 C++
【C/C++学习笔记】C++声明与定义以及头文件与源文件的用途
【C/C++学习笔记】C++声明与定义以及头文件与源文件的用途
46 0
|
4月前
|
C++ Windows
FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg
在Windows上使用Visual Studio 2022进行FFmpeg和SDL2集成开发,首先安装FFmpeg至E:\msys64\usr\local\ffmpeg,然后新建C++控制台项目。在项目属性中,添加FFmpeg和SDL2的头文件及库文件目录。接着配置链接器的附加依赖项,包括多个FFmpeg及SDL2的lib文件。在代码中引入FFmpeg的`av_log`函数输出"Hello World",编译并运行,若看到"Hello World",即表示集成成功。详细步骤可参考《FFmpeg开发实战:从零基础到短视频上线》。
162 0
FFmpeg开发笔记(三十九)给Visual Studio的C++工程集成FFmpeg
|
5月前
|
IDE Linux 开发工具
在Qt开发环境中qmake和cmake的区别优势
选择qmake还是CMake,主要取决于项目的需求和开发者的熟悉程度。如果你正在开发一个纯Qt项目,或者是一个不需要复杂构建脚本的小型项目,qmake可能是一个更好的选择。反之,如果你的项目需要处理复杂的依赖关系,或者你想要一个在多种编程环境中都能工作的构建系统,那么CMake可能是更好的选择。
823 2
|
5月前
Cmake构建Qt项目链接glog库
Cmake构建Qt项目链接glog库

推荐镜像

更多