cmake是一个跨平台的c/c++工程管理工具,可以通过cmake轻松管理我们的项目

conan是一个包管理工具,能够自动帮助我们下载及管理依赖,可以配合cmake使用

这是一个入门教程,想深入了解的我在后面放了几个链接可以去学习

1 cmake

1.1 下载cmake

1.2 cmake的主要命令

cmake -B [target]

[target] 表示我们希望cmake生成文件存放的目录,一般命名为build, 我们也可以进入到build文件夹下使用cmake .. 将cmake生成的文件存放到当前目录

这个命令作用是自动帮我们生成makefile文件

注意事项:build 文件的上一级目录中要有CMakeLists.txt文件,即cmake的描述文件

cmake --build [target]

开始编译,[target]是上一步存放cmake生成文件的目录,如果我们在该目录中 使用cmake --build . 即可

1.3 cmake描述文件CMakeLists.txt初体验

(1)声明需要的cmake的最低版本: 这行必须在描述文件的第一行,这里我设置的最低版本是3.16

cmake_minimum_required(VERSION 3.16)

(2) 添加项目名: 这里我把项目名称设置为cmake

project(cmake)

(3) 添加可执行文件名:这里我设置的可执行文件名是cmake,他依赖的文件是main.cpp,在编译完成后回生成cmake.out或cmake.exe文件

add_executable(cmake main.cpp)

以上三行代码就简单定义好一个cmake描述文件了,这三行也是一个camke描述文件必不可少的

1.4 cmake描述文件再探

上一节介绍了cmake的简单使用,我们的工程不会只有一个文件,也不会只有一个文件夹,否则也不会使用cmake来帮助我们管理,接下来介绍cmake的更多用法

(1) 设置c++版本:指定c++最低编译版本,这里我设置的是14

set(CMAKE_CXX_STANDARD 14)

(2) 指定工程的版本号及语言:使用1.3节第(2)步的命令我们可以为工程设置版本号和指定语言,这里设置的版本号是1.0.0,语言CXX表示c++, 我们可以设置4个字段的版本信息,通过使用配置文件生成头文件在我们的项目中使用版本信息, 4个字段见附录

project(cmake VERSION 1.0.0 LANGUAGES CXX)

(3) 生成静态链接库: 有时候我们的文件可能分散在多个文件夹中,这时我们就可以通过生成静态库的方式将他们链接并生成可执行文件,我们需要在子文件中同样包含CMakeLists.txt文件,然后添加

add_library(libmyHeap STATIC ${CMAKE_CURRENT_SOURCE_DIR}/MyHeap.cpp) # 当前库文件

target_include_directories(libmyHeap PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}) # 头文件

这里通过add_library()指定生成库,libmyHeap 是库的名字,STATIC 指定生成的静态库,${CMAKE_CURRENT_SOURCE_DIR}/MyHeap.cpp 指定我们生成库依赖源文件的路径

${CMAKE_CURRENT_SOURCE_DIR}表示当前CMakeLists.txt所在的文件路径

target_include_directories() 指定生成库依赖的头文件

libmyHeap是生成静态库的名字

PUBLIC 表示当前静态库的依赖可以被上层cmake发现,同时该库也依赖该头文件,当然还有其它设置,作为入门不做介绍

${CMAKE_CURRENT_SOURCE_DIR} 表示当前CMakeLists.txt所在的文件路径

通过这两句命令即可生成一个静态库,要想能被可执行程序链接到,我们只需在顶层CMakeLists.txt文件中添加

add_subdirectory(myHeap) # 添加子目录搜索路径 以及

target_link_libraries(cmake libmyHeap)

首先,第一句add_subdirectory()指定底层CMakeLists.txt的路径,这样我们的顶层CMakeLists.txt就能找到并编译

target_link_libraries()第一个参数指定target即我们的项目名,第二个参数指定要链接的库名

由于我们在上面设置生成静态库时设置可见属性为PUNLIC 因此这里不需要指定头文件路径,cmake就可以通过底层CMakeLists.txt 找到我们需要的头文件,这也是现代cmake的做法

以上就是cmake的基本使用,我们可以把文件放在不同文件夹,并通过生成静态库的方式将各个文件链接起来,这里列出总的CMakeLists.txt文件

顶层CMakeLists.txt

cmake_minimum_required(VERSION 3.16)  # 设置cmake最低版本

project(cmake VERSION 1.0.0 LANGUAGES CXX) # 设置文件名及版本信息

set(CMAKE_CXX_STANDARD 14) # 设置c++版本

add_subdirectory(myHeap) # 添加子目录搜索路径,这里值myHeap路径

add_executable(cmake main.cpp) # 添加可执行文件

target_link_libraries(cmake libmyHeap)  # 链接库名称

底层CMakeLists.txt

add_library(libmyHeap STATIC ${CMAKE_CURRENT_SOURCE_DIR}/MyHeap.cpp) # 当前库文件

target_include_directories(libmyHeap PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}) # 头文件

文件结构

Ok,上面就列出了cmake的简单使用,有时候我们写项目的时候需要使用别人写的库,这个时候一般会下载源码在本地编译或者下载对应版本的编译后的文件,但是我们使用的库还可能包含别人的库,别人的库可能还使用了别别人写的库,这样一个个下载编译太过麻烦,而且有些库还存在多次引入的可能,因此我们需要一个工具帮助我们管理包和依赖,这里介绍conan

2 conan

conan是一个c++包管理工具,一行代码就能将我们需要的包下载到本地并进行编译

注意:目前已知在windows + gcc存在bug,导致编译失败,我也不知什么原因,stackoverflow上有一个提问,说是由于兼容性问题,这里我是直接在linux平台使用

2.1 下载conan

下载很简单,直接通过pip下载

pip install conan

稍等片刻,就下载好了,这个时候如果我们输入conan --version 可能会找不到命令,这是因为环境变量没有添加,添加环境变量网上教程很多

2.2 添加conan配置文件

conanfile.txt这里包含两项,第一项是要下载的库和版本号,第二项是指定生成的管理格式,这里我们选择cmake

以使用poco库为例,我们只需在conanfile.txt中写

 [requires]
poco/1.11.1 [generators]
cmake

这里我们怎么知道所使用的库有哪些版本呢?

可以使用命令conan search poco -r conancenter 获取,其中-r conancenter指定我们需要在conan中央仓库搜索,否则默认本地搜索,要添加其它库,直接在[requires]下添加库名和版本号,然后重新安装就好了

2.3 安装库

我们以及创建好好conan配置文件,下一步,进入build文件夹(这个文件夹就是我们存放cmake生成文件的地方哦),然后一行命令conan install . 即可静静等待下载安装完成了

注意事项: 这个时候可能需要我们指定一些配置信息,配置信息在~/.conan/profiles/default文件里,配置信息需要添加的内容在~/.conan/settings.yml文件里,对于gcc,需要配置compiler.libcxx=libstdc++11 否则以旧版本安装,这里列出我的配置文件供参考

[settings]
os=Linux
os_build=Linux
arch=x86_64
arch_build=x86_64
build_type=Release
compiler=gcc
compiler.libcxx=libstdc++11
compiler.version=9
[options]
[build_requires]
[env]

在这插一条 刚刚吃完饭准备把build文件夹的缓存删了,然后测试一下看看写的对不对,准备输rm -rf build/* 结果输成了rm -rf /*,好家伙.....自闭中...

2.4 在cmake中配置

只需要在顶层CMakeLists.txt文件中添加

include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake)
conan_basic_setup()

${CMAKE_BINARY_DIR}表示当前build文件夹路径, 然后在mian.cpp里引用头文件即可

2.5 使用

现在我么可以使用cmake编译我们我们的工程了

进入到build文件夹下,输入cmake .. 等待生成makefile文件完成后,输入cmake build .等待编译成功了

附录

附录1:cmake变量常用变量

PROJECT_SOURCE_DIR:工程的根目录,顶层CMakeLists.txt所在的目录

PROJECT_BINARY_DIR:cmake生成文件保存的目录,通常为build目录

PROJECT_NAME:项目名

CMAKE_CURRENT_SOURCE_DIR:当前CMakeLists.txt所在的路径

EXECUTABLE_OUTPUT_PATH:重新定义目标二进制可执行文件的存放位置

LIBRARY_OUTPUT_PATH:重新定义目标链接库文件的存放位置

使用格式 ${value}

附录2: 版本号字段 PROJECT-NAME:当前项目名

PROJECT-NAME_VERSION_MAJOR:第一个字段

PROJECT-NAME_VERSION_MINOR:第二个字段

PROJECT-NAME_VERSION_PATCH:第三个字段

PROJECT-NAME_VERSION_TWEAK:第四个字段

附录3:更进一步的学习链接

  1. https://www.zhihu.com/column/c_1369781372333240320 知乎: 很酷的程序员 cmke
  2. https://blog.csdn.net/weixin_39773239/article/details/113052000 CSDN: weixin_39773239 cmake
  3. https://www.bilibili.com/video/BV14h41187FZ B站:IPADS cmake
  4. https://www.bilibili.com/video/BV1wL411u74B B站: bennyhuo不是算命的 conan
  5. https://cmake.org/cmake/help/v3.22/ cmake官方文档

c++ cmake及包管理工具conan简单入门的更多相关文章

  1. c++包管理工具conan

    Conan is a portable package manager, intended for C and C++ developers, but it is able to manage bui ...

  2. PHP包管理工具composer简单总结

    前言 接触laravel之后,才知道有PSR,composer之类的东西,PHP已经不再是一门草根语言了.最近在尝试玩thrift,需要安装PHP thrift依赖库,使用composer insta ...

  3. Node包管理工具

    Node包管理工具 只是简单的介绍一些工具的使用,有利于开发过程.除了介绍Node包管理工具,还介绍了前端打包工具,前端模块管理工具 Node包管理工具:    --npm    --cnpm    ...

  4. Python黑帽编程1.3 Python运行时与包管理工具

    Python黑帽编程1.3  Python运行时与包管理工具 0.1  本系列教程说明 本系列教程,采用的大纲母本为<Understanding Network Hacks Attack and ...

  5. 包管理工具Carthage使用

    iOS项目中第三方开源库的工具有Cocoapods和Carthage,swift官方出了一个包管理工具SPM(Swift Package Manager). 首先,大体讲一下Cocoapods和Car ...

  6. 【转载】Python的包管理工具Pip

    接触了Ruby,发现它有个包管理工具RubyGem很好用,并且有很完备的文档系统http://rdoc.info 发现Python下也有同样的工具,包括easy_install和Pip.不过,我没有细 ...

  7. Python的包管理工具Pip (zz )

    Python的包管理工具Pip 接触了Ruby,发现它有个包管理工具RubyGem很好用,并且有很完备的文档系统http://rdoc.info 发现Python下也有同样的工具,包括easy_ins ...

  8. python 包管理工具

    python 包管理工具 Python当前的包管理工具链是 easy_install/pip + distribute/setuptools + distutils,显得较为混乱. 而将来的工具链组合 ...

  9. Python 包管理工具解惑

    Python 包管理工具解惑 本文链接:http://zengrong.net/post/2169.htm python packaging 一.困惑 作为一个 Python 初学者,我在包管理上感到 ...

随机推荐

  1. Qt Creator打造VScode one dark pro主题配色

    1.缘由 我之前习惯使用 vscode 进行开发,对 vscode 的 one dark pro 主题情有独钟.无奈公司需要使用 Qt Creator 进行日常开发,只能暂时舍弃 vscode,采用曲 ...

  2. 原生css实现fullPage的整屏滚动贴合

    目录 1,前言 2,效果展示 3,属性说明 3.1 scroll-snap-type 3.2,scroll-snap-align 4,实际使用 4.1,兼容性 1,前言 今天摸鱼的时候,发现一个很有意 ...

  3. k8s入坑之路(15)kubernetes共享存储与StatefulSet有状态

    共享存储 docker默认是无状态,当有状态服务时需要用到共享存储 为什么需要共享存储: 1.最常见有状态服务,本地存储有些程序会把文件保存在服务器目录中,如果容器重新启停则会丢失. 2.如果使用vo ...

  4. 攻防世界 WEB 高手进阶区 tinyctf-2014 NaNNaNNaNNaN-Batman Writeup

    攻防世界 WEB 高手进阶区 tinyctf-2014 NaNNaNNaNNaN-Batman Writeup 题目介绍 题目考点 了解js代码(eval函数.splice函数) 了解正则 Write ...

  5. this.$set用法

    this.$set()的主要功能是解决改变数据时未驱动视图的改变的问题,也就是实际数据被改变了,但我们看到的页面并没有变化,这里主要讲this.$set()的用法,如果你遇到类似问题可以尝试下,vue ...

  6. Linux usb 6. HC/UDC 测试

    目录 1. 背景介绍 2. Device (gadget zero) 2.1 gadget zero 创建 2.2 SourceSink Function 2.3 Loopback Function ...

  7. 第一天 python入门 基础 “”“Hello World”和if-elif的使用、数据类型

    (1)第一个程序"""Hello World" 实现python环境打印输出:Hello World 程序: print("Hello World&q ...

  8. Go语言核心36讲(Go语言实战与应用二)--学习笔记

    24 | 测试的基本规则和流程(下) Go 语言是一门很重视程序测试的编程语言,所以在上一篇中,我与你再三强调了程序测试的重要性,同时,也介绍了关于go test命令的基本规则和主要流程的内容.今天我 ...

  9. 让textarea根据文本的长度自动调整它的高度

    ... <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR ...

  10. vue开发中的一些简单骚操作

    在开发过程中,我们可以定义很多参数,这时需要通过不同的操作来改变不同的参数,这就比较复杂了, 虽然不难,但是代码多了也不好看,这时我们就可以通过简单的操作就行简化: 1.对象使用方括号 let obj ...