Cmake知识----编写CMakeLists.txt文件编译C/C++程序

1.CMake编译原理

CMake是一种跨平台编译工具,比make更为高级,使用起来要方便得多。CMake主要是编写CMakeLists.txt文件,然后用cmake命令将CMakeLists.txt文件转化为make所需要的makefile文件,最后用make命令编译源码生成可执行程序或共享库(so(shared object))。因此CMake的编译基本就两个步骤:

1. cmake
2. make

cmake  指向CMakeLists.txt所在的目录,例如cmake .. 表示CMakeLists.txt在当前目录的上一级目录。cmake后会生成很多编译的中间文件以及makefile文件,所以一般建议新建一个新的目录,专门用来编译,例如

mkdir build
cd build
cmake ..
make

make根据生成makefile文件,编译程序。

2.使用Cmake编译程序

我们编写一个关于开平方的C/C++程序项目,即b= sqrt(a),以此理解整个CMake编译的过程。

a.准备程序文件

文件目录结构如下:

.
├── build
├── CMakeLists.txt
├── include
│   └── b.h
└── src
    ├── b.c
    └── main.c

头文件b.h,如下所示:

#ifndef B_FILE_HEADER_INC
#define B_FIEL_HEADER_INC

#include<math.h>

double cal_sqrt(double value);

#endif

 

头文件b.c,如下所示:

#include "../include/b.h"

  • 0
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在代码中包含适当的头文件和链接AWS SDK for C++库。下面是一个简单的示例代码,用于连接到AWS IoT Core并发布一条消息: ```cpp #include <aws/core/Aws.h> #include <aws/iotdata/IotDataClient.h> int main(int argc, char** argv) { Aws::SDKOptions options; Aws::InitAPI(options); Aws::String endpoint = "YOUR_IOT_ENDPOINT_HERE"; Aws::String clientId = "YOUR_CLIENT_ID_HERE"; Aws::String topic = "YOUR_TOPIC_HERE"; Aws::String payload = "YOUR_PAYLOAD_HERE"; Aws::Client::ClientConfiguration config; config.endpointOverride = endpoint; Aws::IotData::IotDataClient iotClient(config); Aws::IotData::Model::PublishRequest request; request.SetTopic(topic); request.SetPayload((const unsigned char*)payload.c_str(), payload.length()); auto outcome = iotClient.Publish(request); if (outcome.IsSuccess()) { std::cout << "Message published successfully!" << std::endl; } else { std::cout << "Failed to publish message: " << outcome.GetError().GetMessage() << std::endl; } Aws::ShutdownAPI(options); return 0; } ``` 在上面的示例中,将AWS IoT Core端点、客户端ID、主题和负载指定为字符串。然后,使用这些值配置AWS SDK for C++的客户端配置。使用`Aws::IotData::IotDataClient`创建一个AWS IoT Data Plane客户端,然后使用`Aws::IotData::Model::PublishRequest`创建一个发布请求对象。在请求对象中设置主题和负载,并使用`iotClient.Publish`方法发布消息。 接下来,你需要编写CMakeLists.txt文件,以便使用AWS SDK for C++库进行静态或动态链接。下面是一个简单的示例CMakeLists.txt文件: ```cmake cmake_minimum_required(VERSION 3.5) project(iotapp) set(CMAKE_CXX_STANDARD 11) option(BUILD_SHARED_LIBS "Build shared libraries" OFF) option(BUILD_STATIC_LIBS "Build static libraries" ON) find_package(aws-sdk-cpp REQUIRED) add_executable(iotapp main.cpp) target_link_libraries(iotapp ${aws-sdk-cpp_LIBRARIES}) ``` 在上面的示例中,使用CMake的`find_package`命令查找AWS SDK for C++库,并将其链接到`iotapp`可执行文件。可以使用`BUILD_SHARED_LIBS`和`BUILD_STATIC_LIBS`选项来指定是否构建共享库或静态库。 最后,使用`cmake`命令生成Makefile并使用`make`命令编译代码: ```bash mkdir build && cd build cmake .. make ``` 如果一切顺利,将生成名为`iotapp`的可执行文件,可以使用`./iotapp`命令运行它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值