当前位置: 首页 > news >正文

CMake 入门实践

CMake 入门实践

    • 第一章 概念与基础项目
      • 1.1 CMake 基础认知
      • 1.2 最小 CMake 项目
      • 1.3 构建流程验证
    • 第二章 多文件项目管理
      • 2.1 项目结构
      • 2.2 源码示例
      • 2.3 CMake 配置
    • 第三章 库文件管理实战
      • 3.1 项目结构
      • 3.2 核心配置
      • 3.3 接口设计
    • 第四章 构建类型与编译优化
      • 4.1 构建类型配置
      • 4.2 构建验证
      • 4.3 不同构建方式
    • 第五章 实用的高级技巧
      • 5.1 变量与缓存机制
      • 5.2 条件控制语句
      • 5.3 自动查找依赖
    • 第六章 跨平台构建实战
      • 6.1 平台检测与处理
      • 6.2 安装规则

第一章 概念与基础项目

1.1 CMake 基础认知

  • 跨平台构建系统生成器:通过抽象生成 Makefile、Visual Studio 项目等
  • 声明式构建系统:描述【要构建什么】,而非【如何构建】
  • 核心文件:通过 CMakeLists.txt 描述项目结构关系

1.2 最小 CMake 项目

// main.cpp
#include <iostream>int main() {std::cout << "Hello CMake! (v1.0)\n";return 0;
}
# CMakeLists.txt
cmake_minimum_required(VERSION 3.10)  # 最低版本保障
project(HelloCMake VERSION 1.0)       # 项目元数据add_executable(hello main.cpp)       # 核心构建指令

1.3 构建流程验证

mkdir build && cd build       # 创建构建目录
cmake ..                     # 生成构建系统文件
cmake --build .              # 执行编译命令
./hello                     # 运行可执行文件

在这里插入图片描述

第二章 多文件项目管理

2.1 项目结构

multi_project/
├── CMakeLists.txt
├── src/
│   ├── main.cpp
│   ├── math.cpp
│   └── math.h

2.2 源码示例

// math.h
#pragma once
int square(int x);
// math.cpp
#include "math.h"int square(int x) {return x * x;
}
// main.cpp
#include "math.h"
#include <iostream>int main() {std::cout << "5² = " << square(5) << std::endl;return 0;
}

2.3 CMake 配置

cmake_minimum_required(VERSION 3.10)
project(MultiFileDemo)# 设置C++标准
set(CMAKE_CXX_STANDARD 14)
set(CMAKE_CXX_STANDARD_REQUIRED ON)# 显式包含目录
include_directories(${PROJECT_SOURCE_DIR}/)# 收集源文件
file(GLOB SOURCES "src/*.cpp")# 创建可执行文件
add_executable(demo ${SOURCES})

在这里插入图片描述

第三章 库文件管理实战

3.1 项目结构

library_project/
├── CMakeLists.txt
├── include/
│   └── calculator.h
├── src/
│   ├── CMakeLists.txt
│   ├── main.cpp
└── lib/├── CMakeLists.txt└── calculator.cpp

3.2 核心配置

# 根目录 CMakeLists.txt
cmake_minimum_required(VERSION 3.15)
project(LibraryDemo)add_subdirectory(lib)
add_subdirectory(src)
# lib/CMakeLists.txt
add_library(calc STATIC calculator.cpp)
target_include_directories(calc PUBLIC${CMAKE_SOURCE_DIR}/include)
# src/CMakeLists.txt
add_executable(app main.cpp)
target_link_libraries(app PRIVATE calc)

3.3 接口设计

// calculator.h
#pragma onceclass Calculator {
public:static double cube(double x);
};
// calculator.cpp
#include "calculator.h"double Calculator::cube(double x) {return x * x * x;
}

int main(void)
{return 0;
}

在这里插入图片描述

第四章 构建类型与编译优化

4.1 构建类型配置

if(NOT CMAKE_BUILD_TYPE)set(CMAKE_BUILD_TYPE "Debug" CACHE STRING"Choose build type" FORCE)
endif()message("当前构建类型: ${CMAKE_BUILD_TYPE}")string(TOUPPER "${CMAKE_BUILD_TYPE}" build_type)if(build_type STREQUAL "DEBUG")add_compile_options(-g -O0 -Wall -Wpedantic)
else()add_compile_options(-O3 -DNDEBUG)
endif()

4.2 构建验证

#include <iostream>
#include <cassert>int main() {
#ifdef NDEBUGstd::cout << "Release 模式\n";
#elsestd::cout << "Debug 模式\n";assert(1 + 1 == 3);  // 测试断言
#endifreturn 0;
}

4.3 不同构建方式

# Debug 模式(默认)
cmake -DCMAKE_BUILD_TYPE=Debug ..
cmake --build .
./demo  # 触发断言错误# Release 模式
cmake -DCMAKE_BUILD_TYPE=Release ..
cmake --build .
./demo  # 关闭断言

第五章 实用的高级技巧

5.1 变量与缓存机制

# 定义普通变量
set(MY_VAR "value")# 缓存变量(用户可配置)
set(USE_FEATURE_X OFF CACHE BOOL "启用特性X")# 环境变量
message("当前PATH: $ENV{PATH}")

5.2 条件控制语句

if(MSVC)add_definitions(-D_WIN32)
elseif(UNIX)add_definitions(-D_LINUX)
endif()

5.3 自动查找依赖

find_package(OpenCV REQUIRED)
if(OpenCV_FOUND)target_link_libraries(my_app PRIVATE ${OpenCV_LIBS})
endif()

第六章 跨平台构建实战

6.1 平台检测与处理

if(WIN32)# Windows特定设置add_definitions(-DWINDOWS_PLATFORM)
elseif(APPLE)# macOS特定设置add_definitions(-DMACOS)
else()# Linux设置add_definitions(-DLINUX)
endif()

6.2 安装规则

install(TARGETS demoRUNTIME DESTINATION binLIBRARY DESTINATION libARCHIVE DESTINATION lib
)install(DIRECTORY include/ DESTINATION include)
http://www.xdnf.cn/news/383293.html

相关文章:

  • 牛客练习赛138
  • 8.5 表格进阶
  • (四)毛子整洁架构(Presentation层/Authentiacation)
  • 批量修改json文件中的标签
  • 【MCAL】TC397+EB-tresos之I2c配置实战(同步、异步)
  • 2025年客运从业资格证备考单选练习题
  • Wallcraft 3.53.0 | 提供高质量动态4D壁纸,解锁高级版,无广告干扰
  • 《Python星球日记》 第50天:深度学习概述与环境搭建
  • 数据治理框架在企业中的落地:从理念到实践
  • OSPF案例
  • 完整进行一次共线性分析
  • Java代理
  • Android开发-图像显示
  • 如何通过合法数据变现实现收入增长
  • LVGL对象的盒子模型和样式
  • Arduino 开源按键库大合集(单击/双击/长按实现)
  • VB与Excel无缝连接实现指南
  • 编译后的js文件如何跟进调试
  • OpenAI的商业化之路:从非营利到盈利的转型
  • IC ATE集成电路测试学习——开尔文连接
  • 最速下降法和梯度下降法的异同
  • python基础(十一)-逻辑运算符
  • nextjs 部署失败:cause: Error: unable to verify the first certificate
  • C语言加餐--一些关键字
  • 数字信号处理|| 离散系统的冲激响应和阶跃响应
  • 【Python训练营打卡】day21 @浙大疏锦行
  • 101alpha第九
  • 一、ArkTS语法学习
  • Qt 界面优化(QSS)
  • 【数据结构与算法】——图(二)