Cmake的CMakeLists.txt写法示例

Cmake的CMakeLists.txt写法示例

目录

  1. 示例一:单文件
  2. 示例二:多个源文件
  3. 示例三:将hello.c生成一个库来调用
  4. 示例四:工程分类文件夹编译
  5. 示例五:Cmake的install使用

示例一:单文件

  1. 文件名字为main.cpp,内容如下:
#include <iostream>

int main() {
    printf("Hello World!\n");
    return 0;
}
  1. CMakeLists.txt文件内容如下,其中:
    a. cmake_minimum_required:对cmake的最低(高)版本的要求。
    b. project:cmake工程的名称,不是强制性的,最好加上。
    c. set:用来定义变量。
    d. add_executable:使用指定的源文件来生成目标可执行文件。
    e. message:输出显示信息。
cmake_minimum_required(VERSION 3.21)
project(cmake-demo)

set(CMAKE_CXX_STANDARD 14)

add_executable(${PROJECT_NAME} main.cpp)

message(${PROJECT_NAME})
  1. CMakeList.txt 文件中,命令名字是不区分大小写的,而参数和变量是大小写相关的。
  2. 编译时在当前目录新建一个build目录,进行build目录执行:cmake …/ ,产生的临时文件就会在build目录下,不影响源码目录代码。
  3. 最后在此目录执行make命令生成相应的可执行程序。
    a. 注:clion中点击执行可自动生成在cmake-build-debug目录中。
    在这里插入图片描述

示例二:多个源文件

  1. hello.h头文件内容如下:
    void hello(const char* name);
  2. hello.cpp文件内容:
#include <stdio.h>
#include "hello.h"
 
void hello(const char* name) {
    printf("Hello my name is %s\n",name);
}
  1. main.c文件内容如下:
#include <iostream>
#include "hello.h"

int main() {
    printf("Hello World!\n");
    hello("hello");
    return 0;
}
  1. CMakeLists.txt文件:
cmake_minimum_required(VERSION 3.21)
project(cmake-demo)

set(CMAKE_CXX_STANDARD 14)
set(SRC_LIST main.cpp hello.cpp hello.h)

add_executable(${PROJECT_NAME} ${SRC_LIST})

message(${PROJECT_NAME})

示例三:将hello.c生成一个库来调用

  1. 如果将hello生成成一个库来调用的话只需要在事例二的基础上修改一下CMakeLists.txt文件再进行编译。
  2. 修改的CMakeLists.txt如下:
    a. add_library:指定的源文件生成链接文件添加到工程中。
    b. target_link_libraries:将目标文件与库文件进行链接。
cmake_minimum_required(VERSION 3.21)
project(cmake-demo)

set(CMAKE_CXX_STANDARD 14)
set(LIB_SRC hello.cpp)
set(SRC_LIST main.cpp)

add_library(hello ${LIB_SRC})

add_executable(${PROJECT_NAME} ${SRC_LIST})

target_link_libraries(${PROJECT_NAME} hello)

message(${PROJECT_NAME})
  1. 与事例二相比,添加了一个新的目标hello库,并将其链接到我们的cmake-demo程序。
  2. 然后用同样的方法进行cmake和make进行编译。

示例四:工程分类文件夹编译

  1. 如果代码量比较大,会将代码分开放置,进行分类,形成分成多个文件夹。

  2. 比如main.cpp程序放在app目录下面,hello.cpp和hello.h放在libso文件夹下面。
    a. 当前文件夹有一个CMakeLists.txt文件,app和libso文件夹下面也有CMakeLists.txt文件。
    在这里插入图片描述

  3. 首先看app文件夹的CMakeLists.txt。

project(cmake-demo)

include_directories(${PROJECT_SOURCE_DIR}/../../libso)

set(SRC_LIST main.cpp)
add_executable(${PROJECT_NAME} ${SRC_LIST})
target_link_libraries(${PROJECT_NAME} helloso)

message(${PROJECT_NAME})
  1. 然后看libso文件夹的CMakeLists.txt,其中SHARED表示是生成的动态库,如果把SHARED去掉的话就是生成静态库。
project(helloso)

set(LIB_SRC hello.cpp)
add_library(${PROJECT_NAME} SHARED ${LIB_SRC})
  1. 最外面文件夹的CMakeLists.txt:
cmake_minimum_required(VERSION 3.21)
project(cmake)

add_subdirectory(./app)
add_subdirectory(./libso)

在这里插入图片描述

  1. 最后到build目录下执行 cmake …/ 和 make 进行编译。生成目录如下:
    a. 注:clion中点击执行可自动生成在cmake-build-debug目录中。

示例五:Cmake的install使用

  1. cmake中install是将编译好的可执行文件或者生成的库文件放到系统对应的位置,比如说可执行文件直接要放到bin目录下面,so库文件要放到对应的lib目录下面。
  2. 修改上面例子的CMakeLists.txt文件,编辑完成后编译多了install步骤,这样可以在Linux上面使用该执行文件,执行文件会调用so库。即执行命令为:
cmake ../
make
make install
  1. app目录修改的CMakeLists.txt在最后一行加上install:
project(cmake-demo)

include_directories(${PROJECT_SOURCE_DIR}/../../libso)

set(SRC_LIST main.cpp)
add_executable(${PROJECT_NAME} ${SRC_LIST})
target_link_libraries(${PROJECT_NAME} helloso)

message(${PROJECT_NAME})

install(TARGETS ${PROJECT_NAME} DESTINATION bin)
  1. libso目录修改的CMakeLists.txt在最后一行加上install:
project(helloso)

set(LIB_SRC hello.cpp)
add_library(${PROJECT_NAME} SHARED ${LIB_SRC})

install(TARGETS ${PROJECT_NAME} DESTINATION ../lib)
  1. 解释:
    a. install(TARGETS ${PROJECT_NAME} DESTINATION bin):安装cmake-demo可执行文件到${CMAKE_INSTALL_PREFIX}/bin目录。
    b. 可以自行打印CMAKE_INSTALL_PREFIX路径,比如/usr/local,注意bin前面不能有/。
    c. 所以执行行文件的路径是/usr/local/bin/,so库文件的安装路径是:/usr/local/…/lib/
    d. 此时可以在Linux系统任何目录里执行./cmake-demo
    e. 如果执行make install的时候出现错误,加上sudo再次执行。
### 回答1: CMake是一个跨平台的构建工具,用于帮助开发者生成各种不同编译工具的构建脚本。在编写CMakeLists.txt文件时,可以使用多个源文件进行编译。 首先,在CMakeLists.txt文件中使用`add_executable`或`add_library`命令来指定生成的可执行文件或库文件的名称,并将其与源文件关联起来。 例如,如果我们有两个源文件main.cpp和helper.cpp,我们可以这样写: ```cmake cmake_minimum_required(VERSION 3.12) project(MyProject) add_executable(MyExecutable main.cpp helper.cpp) ``` 这个例子中,我们使用`add_executable`命令来生成一个名为MyExecutable的可执行文件,并将main.cpp和helper.cpp这两个源文件与之关联。 如果我们的项目中有更多的源文件,我们可以继续在`add_executable`或`add_library`命令后面继续添加源文件的名称。 ```cmake add_executable(MyExecutable main.cpp helper.cpp file1.cpp file2.cpp) ``` 当我们构建项目时,CMake会自动将这些源文件编译成目标文件,并链接到生成的可执行文件或库文件中。 此外,如果项目中有多个文件夹,并且每个文件夹中都有一些源文件,可以使用`add_subdirectory`命令将这些文件夹添加到构建过程中。 ```cmake add_subdirectory(folder1) add_subdirectory(folder2) ``` 这样可以让CMake在构建过程中进入这些文件夹并执行相应的CMakeLists.txt文件。 总结起来,CMakeLists.txt文件中的多文件编译可以通过`add_executable`或`add_library`命令与源文件进行关联,以及使用`add_subdirectory`命令将多个文件夹添加到构建过程中。 ### 回答2: cmakelists.txt是用于配置CMake编译和构建项目的脚本文件,它使用简单的语法来描述项目的文件结构和依赖关系。如果需要编译多个源文件,可以按照以下步骤编写CMakeLists.txt: 1. 设置项目名称和最低CMake版本: ```cmake cmake_minimum_required(VERSION 3.10) project(MyProject) ``` 2. 添加源文件到项目中,可以使用SET命令将需要编译的源文件路径存储在变量中: ```cmake set(SOURCES src/main.cpp src/other.cpp) ``` 3. 添加可执行文件目标,并将源文件与目标进行关联: ```cmake add_executable(MyExecutable ${SOURCES}) ``` 4. 如果需要链接外部库,可以使用target_link_libraries命令来指定链接的库: ```cmake target_link_libraries(MyExecutable MyLibrary) ``` 完整示例CMakeLists.txt文件: ```cmake cmake_minimum_required(VERSION 3.10) project(MyProject) set(SOURCES src/main.cpp src/other.cpp) add_executable(MyExecutable ${SOURCES}) target_link_libraries(MyExecutable MyLibrary) ``` 以上是最基本的多文件编译的CMakeLists.txt的编写方式,根据实际项目需求,还可以添加更多的配置选项和设置,例如编译选项、包含路径、链接库等。具体的写法会因项目而异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值