0

0

c++怎么使用CMake来管理一个项目_c++项目构建与跨平台编译配置教程

尼克

尼克

发布时间:2025-11-17 13:37:49

|

272人浏览过

|

来源于php中文网

原创

首先创建项目结构并编写CMakeLists.txt,然后配置C++标准与头文件路径,接着编写示例代码,通过build目录执行cmake生成构建系统并编译,最后注意跨平台路径与库链接问题。

c++怎么使用cmake来管理一个项目_c++项目构建与跨平台编译配置教程

在现代C++开发中,使用CMake来管理项目已成为标准做法。它能帮助你清晰组织代码结构、简化编译流程,并实现跨平台构建(Windows、Linux、macOS等)。下面是一个实用的C++项目构建与跨平台编译配置教程,带你从零开始使用CMake。

1. 项目基础结构

一个典型的CMake项目目录结构如下:

my_project/
├── CMakeLists.txt
├── src/
│ └── main.cpp
└── include/
└── my_header.h

这个结构将源码(src)、头文件(include)和构建配置(CMakeLists.txt)分离,便于维护。

2. 编写根目录 CMakeLists.txt

在项目根目录创建 CMakeLists.txt,内容如下:

立即学习C++免费学习笔记(深入)”;

cmake_minimum_required(VERSION 3.10)
project(MyProject VERSION 1.0 LANGUAGES CXX)

设置C++标准

set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

添加可执行文件

add_executable(${PROJECT_NAME}
src/main.cpp
)

包含头文件目录

target_include_directories(${PROJECT_NAME} PRIVATE include)

说明:

  • cmake_minimum_required:指定所需最低CMake版本。
  • project:定义项目名称、版本和语言。
  • set(CMAKE_CXX_STANDARD ...):启用C++17标准(也可改为14或20)。
  • add_executable:将源文件编译为可执行程序。
  • target_include_directories:让编译器能找到头文件。

3. 示例代码:main.cpp 与头文件

include/my_header.h

#ifndef MY_HEADER_H
#define MY_HEADER_H

void say_hello();

endif // MY_HEADER_H

Artbreeder
Artbreeder

创建令人惊叹的插画和艺术

下载

src/main.cpp

#include iostream>
#include "my_header.h"

void say_hello() {
std::cout }

int main() {
say_hello();
return 0;
}

4. 构建项目(跨平台通用步骤)

打开终端,进入项目根目录,执行以下命令:

mkdir build
cd build
cmake ..
cmake --build .

解释:

  • mkdir build:创建独立的构建目录(推荐做法,避免污染源码)。
  • cmake ..:读取上级目录的CMakeLists.txt,生成对应平台的构建系统(如Makefile或Visual Studio工程)。
  • cmake --build .:调用底层构建工具(make、ninja、MSBuild等)完成编译。

构建成功后,可在build目录下找到生成的可执行文件(如MyProject或MyProject.exe)。

5. 跨平台注意事项

CMake本身是跨平台的,但需注意以下几点:

  • 路径分隔符:使用正斜杠 /,CMake会自动处理不同系统的差异。
  • 编译器兼容性:确保目标平台安装了支持C++17的编译器(g++、clang、MSVC等)。
  • 生成器选择:可通过 -G 指定生成器,例如:
    cmake -G "Unix Makefiles" ..
    或 Windows 上:
    cmake -G "Visual Studio 17 2022" ..

6. 引入第三方库(以静态库为例)

假设你有一个第三方库 libmath.a 和对应的头文件:

# 在CMakeLists.txt中添加
add_library(math STATIC IMPORTED)
set_property(TARGET math PROPERTY IMPORTED_LOCATION /path/to/libmath.a)
target_include_directories(math INTERFACE /path/to/math_headers)

链接到主程序

target_link_libraries(${PROJECT_NAME} math)

对于常用库(如Boost、OpenCV),可使用 find_package() 自动查找。

基本上就这些。掌握以上内容后,你已经可以用CMake高效管理中小型C++项目,并轻松实现跨平台编译。随着项目变大,可以进一步学习子目录CMakeLists.txt、函数封装、编译选项控制等高级特性。

相关专题

更多
typedef和define区别
typedef和define区别

typedef和define区别在类型检查、作用范围、可读性、错误处理和内存占用等。本专题为大家提供typedef和define相关的文章、下载、课程内容,供大家免费下载体验。

107

2023.09.26

define的用法
define的用法

define用法:1、定义常量;2、定义函数宏:3、定义条件编译;4、定义多行宏。更多关于define的用法的内容,大家可以阅读本专题下的文章。

335

2023.10.11

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

537

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

197

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

97

2025.11.27

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.1万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号