cmake+CMakeLists的学习

本文通过逐步实例介绍了如何使用CMake构建项目,从最简单的单个源文件开始,到包含多个源文件及静态库、动态库的构建。详细讲述了CMakeLists.txt的配置过程,并解释了在生成动态库时需要注意的导出函数规则。

一、我们想来看一个最简单的例子:

1.新建一个src文件夹,在src文件夹下新建一个main.cpp以及一个CMakeLists.txt,然后分别添加如下内容:

main.cpp

#include <QtCore/QCoreApplication>
#include <QtCore/QDebug>
int main(int argc, char** argv)
{
    QCoreApplication app(argc, argv);
    qDebug()<<"hello qt!";
    app.exec();
}

CMakeLists.txt

cmake_minimum_required(VERSION 2.8.4)

project(example)

find_package(Qt4 REQUIRED)
set(QT_DONT_USE_QTGUI TRUE)
include(${QT_USE_FILE})
add_executable(example main.cpp)
target_link_libraries(example ${QT_LIBRARIES})


2.在src文件夹的同级目录下新建一个bin文件夹,然后打开CMake(cmake-gui),如下图,在1处添加src路径,在2处添加bin路径,然后执行第3步“Configure”,再执行第4步“Generate”,如果第5处没有错误显示则为cmake成功。


3.打开bin文件夹下的example.vcxproj工程,先“生成->生成解决方案”,然后按“Ctrl+F5”运行。程序运行成功会显示如下界面:


二、我们再测试一个稍微复杂点的例子:

1.同样的,我们再新建一个src文件夹,在src文件夹下新建一个main.cpp以及一个CMakeLists.txt,不同的是我们再新建一个person.cpp和person.h的文件,然后分别添加如下内容:

main.cpp

#include <iostream>
using namespace std;
#include "person.h"

int main(int argc, char *argv[])
{
    cout << "Hello World!" << endl;
    Person juan(18,"Juan");
    cout<<"My name is "<<juan.getName()<<", "<<juan.getAge()<<" years old!"<<endl;
    return 0;
}

person.cpp

#include "person.h"

Person::Person(int age, string name)
{
    this->age = age;
    this->name = name;
}

int Person::getAge()
{
    return age;
}

string Person::getName()
{
    return name;
}

person.h

#ifndef PERSON_H
#define PERSON_H

#ifdef _WIN32
    #ifdef LIBPERSON_BUILD
        #define LIBPERSON_API __decl
### 如何在 VSCode 中使用 CMake 进行项目构建 #### 配置环境 为了能够在 VSCode 中顺利使用 CMake 构建项目,需先确认已安装好 CMake 和相应的工具链。对于 Windows 用户来说,可以通过Chocolatey、Scoop 或者直接下载官方安装包来完成 CMake 的安装[^1];Linux 用户通常可以直接通过包管理器如 `apt` 来获取最新版本的 CMake。 #### 安装扩展插件 VSCode 提供了一个名为 "CMake Tools" 的扩展插件,该插件极大地简化了基于 CMake 的项目的配置和编译过程。安装此插件之后,在打开含有 CMakeLists.txt 文件的工作区时会自动检测并提示初始化设置[^2]。 #### 初始化项目结构 创建一个新的文件夹作为工作目录,并在此文件夹内建立必要的源代码文件以及根级别的 CMakeLists.txt 文件定义整个工程的目标及其依赖关系。例如: ```cmake project(MyProject VERSION 0.1 LANGUAGES CXX) add_executable(${PROJECT_NAME} main.cpp) ``` #### 使用命令面板操作 一旦上述准备工作就绪,则可通过调用 VSCode 命令面板(Ctrl+Shift+P),输入"CMake:" 开始执行各种与 CMake 相关的任务,比如选择套接字位置、缓存清理、重新加载缓存等。特别值得注意的是,“CMake: Configure”,这一步骤用于指定生成哪种类型的构建系统文件(如 Makefiles 或 Ninja build files)。而 “CMake: Build” 则是用来实际触发构建流程。 #### 自动化调试体验 除了基本的构建功能外,还可以进一步定制 launch.json 文件中的调试选项以便更好地支持断点调试等功能。当一切准备妥当时,只需点击左侧边栏上的绿色播放按钮即可启动应用程序并进入交互模式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Suffering-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值