详解Ubuntu18.04配置VSCode+CMake的C++开发环境

首先,介绍自己电脑:Ubuntu18.04、VS Code 1.46版

本文目的:为VS Code配置好C++ 开发环境,以及VS Code +CMake的配置

对于C++ 工程,有四个必要的json配置文件,先ctrl+shift+p打开输入指令分别是:

  • c_cpp_properties.json配置项目结构,自动生成和更新,输入C/C++:Edit configuration
  • task.json: 构建和编译运行项目,输入Task:Configure Task,模板,Others
  • launch.json: 调试,读取可执行文件
  • setting.json: 输入setting

针对两种情况分别进行介绍,最后根据十四讲中使用Eigen进行实验。

一、VS Code 的C++开发环境

摘要
1.新建C/C++工程,VScode以文件夹为管理工程的方式,因此需要建立一个文件夹来保存工程。
2.配置launch.json文件,读取可执行文件。需要进行修改地方的是指定运行的文件,其次我们还可以在里面添加build任务,用于调试
3.配置tasks.json文件,这个文件用来方便用户自定义任务,我们可以通过这个文件来添加g++/gcc或者是make命令,方便我们编译程序
4.之后就可以进行基础的C/C++开发与调试了。

1、建立工程

新建一个工作区文件夹,然后在VScode中打开这个文件夹。VScode调试必须在工作区文件夹下,单独打开一个文件调试会报错。VScode不支持中文路径,文件夹名称不能有空格。

#include <iostream>
using namespace std;

int main(){
 cout<<"Hello World"<<endl;
 getchar();
 return 0;
}

2、更改配置文件(launch.json)

launch.json目的:读取执行out文件

点击左侧的Debug按钮,选择添加配置(Add
configuration),然后选择C++(GDB/LLDB),然后点击默认生成,将自动生成launch.json文件,具体操作如下:

{
 // 使用 IntelliSense 了解相关属性。
 // 悬停以查看现有属性的描述。
 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
  {
   "name": "(gdb) 启动",// 配置名称
   "type": "cppdbg",// 配置类型
   "request": "launch",// 请求配置类型,launch或者attach
   "program": "输入程序名称,例如 ${workspaceFolder}/a.out",// 进行调试程序的路径,程序生成文件.out
   "args": [],// 传递给程序的命令行参数,一般为空
   "stopAtEntry": false,// 调试器是否在目标的入口点停止,
   "cwd": "${workspaceFolder}",// 项目目录
   "environment": [],
   "externalConsole": false,// 调试时是否显示控制台窗口,一般为true显示控制台
   "MIMode": "gdb",// 指定连接的调试器
   "setupCommands": [
    {
     "description": "为 gdb 启用整齐打印",
     "text": "-enable-pretty-printing",
     "ignoreFailures": true
    }
   ]
  }
 ]
}

更改
将program内容改为调试时运行的程序。

"program": "输入程序名称,例如 ${workspaceFolder}/a.out"

改为

"program": "${workspaceFolder}/${fileBasenameNoExtension}.out"

新增,preLaunchTask 使得每次调试之前会自动进行build:

"preLaunchTask": "build",

最终版本为:

{
 // Use IntelliSense to learn about possible attributes.
 // Hover to view descriptions of existing attributes.
 // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
  {
   "name": "(gdb) Launch",
   "type": "cppdbg",
   "request": "launch",
   "program": "${workspaceFolder}/${fileBasenameNoExtension}.out",
   "args": [],
   "stopAtEntry": false,
   "cwd": "${workspaceFolder}",
   "environment": [],
   "externalConsole": true,
   "MIMode": "gdb",
   "preLaunchTask": "build",
   "setupCommands": [
    {
     "description": "Enable pretty-printing for gdb",
     "text": "-enable-pretty-printing",
     "ignoreFailures": true
    }
   ]
  }
 ]
}

3、更改编译任务(task.json)

task.json:定义编译方法,转为计算机可识别的语言,生成out文件

快捷键ctrl+shift+p打开命令行,输入:Task:Configure Task 使用模版创建Tasks.json文件 →
Others:

{
 // See https://go.microsoft.com/fwlink/?LinkId=733558
 // for the documentation about the tasks.json format
 "version": "2.0.0",
 "tasks": [
  {
   "label": "echo",// 任务名
   "type": "shell",
   "command": "echo Hello" // 指令
  }
 ]
}

更改为:

{
 // See https://go.microsoft.com/fwlink/?LinkId=733558
 // for the documentation about the tasks.json format
 "version": "2.0.0",
 "tasks": [
  {
   "label": "build",
   "type": "shell",
   "command": "g++",
   "args": ["-g", "${file}", "-std=c++11", "-o", "${fileBasenameNoExtension}.out"]
  }
  ]
}

4、断点调试

以上工作完成后即可编译运行C/C++程序。不过在调试之前最好先CTRL+SHIFT+B编译一下,选择执行我们的build任务,build成功后,点击开始调试。

二、CMake调试C++ 工程

1、创建文件

在文件夹内创建文件

~$ touch main.cpp
~$ touch CMakeLists.txt

CMakeLists.txt

cmake_minimum_required(VERSION 2.6)
 # 工程vscode_cmake
project(vscode_cmake)

#dubug 模式
set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g")

set(SRC_LIST main.cpp)
# 可执行程序 result
add_executable(result ${SRC_LIST})

main.cpp

#include<iostream>

using namespace std;

int main(){

 int a = 2+3;
 int b = a+3;

 for(int i = 0; i<10; i++){
  cout<<"hello vs code & cmake..."<<endl;
 }

 return 0;
}

其中, 需要在CMakeLists.txt 里加
set (CMAKE_CXX_FLAGS “${CMAKE_CXX_FLAGS} -g”)
开启debug 不然断点调试是无效的

2、开始调试

首先要build生成可执行文件result,有了可执行文件才能进行debug操作,然后再设置断点,按下F5,进行调试。

在图中最左侧第四个小蜘蛛形状的图标(调试),点击左上方的小齿轮,添加配置(C++GDB/LLDB),修改launch.json文件为:

{
 // 使用 IntelliSense 了解相关属性。
 // 悬停以查看现有属性的描述。
 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
  {
   "name": "(gdb) 启动",
   "type": "cppdbg",
   "request": "launch",
   "program": "${workspaceFolder}/build/result",// 更改
   "args": [],
   "stopAtEntry": false,
   "cwd": "${workspaceFolder}",
   "environment": [],
   "externalConsole": false,
   "MIMode": "gdb",
   "setupCommands": [
    {
     "description": "为 gdb 启用整齐打印",
     "text": "-enable-pretty-printing",
     "ignoreFailures": true
    }
   ]
  }
 ]
}

更改了

"program": "${workspaceFolder}/build/result",// 更改

是为了生成的可执行文件result到build文件夹内。
之后按下最下方的Build按键,生成可执行文件。

接下来设置断点,按下F5,进行调试

3、配置 C++ IntelliSense

Ctrl+shift+p打开命令选项,选择C/C++:Edit configuration ,自动生成 c_cpp_properties.json配置文件。

{
 "configurations": [
  {
   "name": "Linux",
   "includePath": [
    "${workspaceFolder}/**"
   ],
   "defines": [],
   "compilerPath": "/usr/bin/clang",
   "cStandard": "c11",
   "cppStandard": "c++14",
   "intelliSenseMode": "clang-x64",
   "configurationProvider": "ms-vscode.cmake-tools"
  }
 ],
 "version": 4
}

最主要的事includePath的引用和库的路径,根据引用内容进行配置。

三、实例分析

打开《视觉SLAM十四讲》的ch3的useGeometry文件夹
CmakeLists.txt:

cmake_minimum_required( VERSION 2.8 )
project( geometry )

# 添加Eigen头文件
include_directories( "/usr/include/eigen3" )

add_executable( eigenGeometry eigenGeometry.cpp )

eigenGeometry.cpp:

#include <iostream>
#include <cmath>
using namespace std;

#include <Eigen/Core>
// Eigen 几何模块
#include <Eigen/Geometry>

/****************************
* 本程序演示了 Eigen 几何模块的使用方法
****************************/

int main ( int argc, char** argv )
{
 // Eigen/Geometry 模块提供了各种旋转和平移的表示
 // 3D 旋转矩阵直接使用 Matrix3d 或 Matrix3f
 Eigen::Matrix3d rotation_matrix = Eigen::Matrix3d::Identity();
 // 旋转向量使用 AngleAxis, 它底层不直接是Matrix,但运算可以当作矩阵(因为重载了运算符)
 Eigen::AngleAxisd rotation_vector ( M_PI/4, Eigen::Vector3d ( 0,0,1 ) );  //沿 Z 轴旋转 45 度
 cout .precision(3);
 cout<<"rotation matrix =\n"<<rotation_vector.matrix() <<endl;    //用matrix()转换成矩阵
 // 也可以直接赋值
 rotation_matrix = rotation_vector.toRotationMatrix();
 // 用 AngleAxis 可以进行坐标变换
 Eigen::Vector3d v ( 1,0,0 );
 Eigen::Vector3d v_rotated = rotation_vector * v;
 cout<<"(1,0,0) after rotation = "<<v_rotated.transpose()<<endl;
 // 或者用旋转矩阵
 v_rotated = rotation_matrix * v;
 cout<<"(1,0,0) after rotation = "<<v_rotated.transpose()<<endl;

 // 欧拉角: 可以将旋转矩阵直接转换成欧拉角
 Eigen::Vector3d euler_angles = rotation_matrix.eulerAngles ( 2,1,0 ); // ZYX顺序,即roll pitch yaw顺序
 cout<<"yaw pitch roll = "<<euler_angles.transpose()<<endl;

 // 欧氏变换矩阵使用 Eigen::Isometry
 Eigen::Isometry3d T=Eigen::Isometry3d::Identity();    // 虽然称为3d,实质上是4*4的矩阵
 T.rotate ( rotation_vector );          // 按照rotation_vector进行旋转
 T.pretranslate ( Eigen::Vector3d ( 1,3,4 ) );      // 把平移向量设成(1,3,4)
 cout << "Transform matrix = \n" << T.matrix() <<endl;

 // 用变换矩阵进行坐标变换
 Eigen::Vector3d v_transformed = T*v;        // 相当于R*v+t
 cout<<"v tranformed = "<<v_transformed.transpose()<<endl;

 // 对于仿射和射影变换,使用 Eigen::Affine3d 和 Eigen::Projective3d 即可,略

 // 四元数
 // 可以直接把AngleAxis赋值给四元数,反之亦然
 Eigen::Quaterniond q = Eigen::Quaterniond ( rotation_vector );
 cout<<"quaternion = \n"<<q.coeffs() <<endl; // 请注意coeffs的顺序是(x,y,z,w),w为实部,前三者为虚部
 // 也可以把旋转矩阵赋给它
 q = Eigen::Quaterniond ( rotation_matrix );
 cout<<"quaternion = \n"<<q.coeffs() <<endl;
 // 使用四元数旋转一个向量,使用重载的乘法即可
 v_rotated = q*v; // 注意数学上是qvq^{-1}
 cout<<"(1,0,0) after rotation = "<<v_rotated.transpose()<<endl;

 return 0;
}

launch.json配置为:

{
 // 使用 IntelliSense 了解相关属性。
 // 悬停以查看现有属性的描述。
 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
  {
   "name": "(gdb) 启动",
   "type": "cppdbg",
   "request": "launch",
   "program": "${workspaceFolder}/build/eigenGeometry",// 更改
   "args": [],
   "stopAtEntry": false,
   "cwd": "${workspaceFolder}",
   "environment": [],
   "externalConsole": false,
   "MIMode": "gdb",
   "setupCommands": [
    {
     "description": "为 gdb 启用整齐打印",
     "text": "-enable-pretty-printing",
     "ignoreFailures": true
    }
   ]
  }
 ]
}

task.json配置为:

{
 // See https://go.microsoft.com/fwlink/?LinkId=733558
 // for the documentation about the tasks.json format
 "version": "2.0.0",
 "tasks": [
  {
   "label": "make build",//编译的项目名,build,更改
   "type": "shell",
   "command": "cd ./build ;cmake ../ ;make",//编译命令,更改
   "group": {
    "kind": "build",
    "isDefault": true
   }
  },
  {
   "label": "clean",
   "type": "shell",
   "command": "make clean",

  }
 ]
}

c_cpp_properties.json

{
 "configurations": [
  {
   "name": "Linux",
   "includePath": [

    "${workspaceFolder}/**", // 更改
    "/usr/include",
    "/usr/local/include"
   ],
   "defines": [],
   "compilerPath": "/usr/bin/gcc",
   "cStandard": "c11",
   "cppStandard": "c++17",
   "intelliSenseMode": "clang-x64",
   "compileCommands": "${workspaceFolder}/build/compile_commands.json"// 更改
  }
 ],
 "version": 4
}

按下build生成可执行文件eigenGeometry

生成可执行文件后,按下F5,进行调试

参考:

https://blog.csdn.net/weixin_43374723/article/details/84064644
https://blog.csdn.net/zzz_xxj/article/details/86568353
https://blog.csdn.net/wanzew/article/details/83097457
https://blog.csdn.net/orange_littlegirl/article/details/88397361

到此这篇关于详解Ubuntu18.04配置VSCode+CMake的C++开发环境的文章就介绍到这了,更多相关VSCode CMake配置C++开发环境内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • centos 7 vscode cmake 编译c++工程的教程详解

    一.环境说明 1)gcc/g++  cmake安装建议 gcc/g++内核自带的即可,如果需要新的自行安装, cmake也一样,如有需要新的版本自行安装. 2)vscode安装插件 必要的插件c/c++ 0.28.1 cmake 0.0.17 cmake tools 1.4  (这几个插件的版本可能会不同,以扩展搜索到的最新的为准) 二.创建项目实验 1)打开项目文件夹 第一步:打开vscode,点击左上角文件,在下拉菜单选择打开文件夹!注意,是打开文件夹,不是工作区,也不是其它的!! 第二步:

  • vscode和cmake编译多个C++文件的实现方法

    目的是利用vscode及相关插件编译多个C++文件. 我已经装好cmake和mingw并且将它们的路径添加到系统变量path中了. vscode装上如下几个插件: 点击vscode左上角 文件->首选项->设置,弹出如下窗口: cmake tools里头有一项cmake.preferredGenerators要根据编译器修改成对应的值,mingw对应的是MinGW Makefiles 下面一项cmake要配置cmake的安装路径,我的是C:\\Program Files\\CMake\\bin

  • VSCODE+cmake配置C++开发环境的实现步骤

    1.引言 在实习期间,感受到在vs code上编程的优势(实习期间主要写的lua脚本),因此想把C++和python的开发也迁移到vs code上.如果只运行一个简单的.cpp文件,那么使用万能的Code Runner插件就可以完成编译等任务.但是,一般的C++开发中,不可能只有一个.cpp文件,还会自定义头文件和相应的源文件,此时Code Runner就无法满足我们的要求.对于编译多个C++源文件,我网上查到的资料主要有两种方法: (1)配置tasks.json文件 在tasks.json文件

  • Windows配置VSCode+CMake+Ninja+Boost.Test的C++开发环境(教程详解)

    平时习惯了在Linux环境写C++,有时候切换到Windows想继续在同一个项目上工作,重新配置环境总是很麻烦.虽然Windows下用Visual Studio写C++只需要双击个图标,但我还是想折腾一下VS Code的环境配置.原因主要有两点:一是个人习惯上各种语言都在VS Code里面写,利用Git同步代码可以很方便地在不同平台开发同一个项目:二是有些情形下无法使用图形化界面,比如为Git配置CI(持续性集成)时显然不能用Visual Studio这个图形化的IDE来执行Windows环境的

  • 详解Ubuntu18.04配置VSCode+CMake的C++开发环境

    首先,介绍自己电脑:Ubuntu18.04.VS Code 1.46版 本文目的:为VS Code配置好C++ 开发环境,以及VS Code +CMake的配置 对于C++ 工程,有四个必要的json配置文件,先ctrl+shift+p打开输入指令分别是: c_cpp_properties.json :配置项目结构,自动生成和更新,输入C/C++:Edit configuration task.json: 构建和编译运行项目,输入Task:Configure Task,模板,Others lau

  • Ubuntu16.04下配置VScode的C/C++开发环境

    1. Vscode安装 Visual studio code是微软发布的一个运行于 Mac OS X.Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器.第一种方式是从VScode官网下载.deb文件,然后双击该文件会打开软件中心进行安装. 另一种方式是通过Terminal进行安装,首先输入下面三条语句安装umake: sudo add-apt-repository ppa:ubuntu-desktop/ubuntu-make sudo apt-get u

  • Ubuntu 20.04 下安装配置 VScode 的 C/C++ 开发环境(图文教程)

    前言: 之前安装了Ubuntu 18.04,结果在安装Codeblocks / VScode还是安装gcc,c/c++的时候出现了一堆错误(缺失依赖树等等问题,换源也无法成功),整了一个下午没有任何进展,网上找不到任何解决方法,于是只能重装了Ubuntu 20.04,之后Codeblocks倒是安装成功了,但是明明在已经安装了C/C++跟GCC编译包的情况,它仍然显示在该路径下找不到,无论路径是默认自动定位在/usr 还是在/usr/bin 之下仍然出现此情况,同样网上找不到任何解决方法,于是只

  • 详解Ubuntu18.04下配置Nginx+RTMP+HLS+HTTPFLV服务器实现点播/直播/录制功能

    2019.9.4更新 继续玩又发现个好玩的东西,nginx-http-flv-module模块,集成了之前的RTMP模块,又有httpflv模块,还是咱们国内程序员大神开发维护,真是开心,国内的大神如此出色,为他们这些愿意分享技术的人点32个赞,具体的编译和安装方式与RTMP模块基本一样,配置readme中也说得很详细,就不赘述了,需要注意的一点是,httpflv方式客户端想看也是需要服务设置cors的,这点readme中没有提到好像. 2019.6.27更新 再更新个windows版本的搭建方

  • 详解Windows下运用Docker部署Node.js开发环境

    开始 在windows下部署nodejs开发环境着实遍地坑,每遇到一个问题都要去google原因再试图解决.而且如果你想把你写好的应用交给别人跑跑看,他可能同样需要折腾很久才能真正在他的环境下运行起来.被坑了好些时日最终还是放弃,转战Docker. 文章开头先明确一下我们希望实现的效果: 1.依然在Windows下编辑源代码,在Docker容器中运行代码,最后在Windows的浏览器中看到运行结果,方便后续debug. 2.可以将我开发完成的程序和运行环境一起打包制作成Docker的image,

  • 详解ubuntu20.04下CLion2020.1.3安装配置ROS过程说明

    一 下载安装激活CLion 按照网上给的教程就可以 二 配置ROS 1.配置CLion的启动方式 在主目录打开隐藏文件.bashrc,命令是:sudo gedit ~/.bashrc 将CLion的启动文件clion.sh的路径设置为环境变量 PATH 这样在终端里,无论在哪个工作目录下都可以输入clion.sh即可启动CLion. 设置的代码是: export PATH=/home/zyw/CLionPack/clion-2020.1.3/bin:$PATH 这个路径是安装CLion的路径,不

  • 详解git中配置的.gitignore不生效的解决办法

    详解git中配置的.gitignore不生效的解决办法 前言: 通常我们希望放进仓库的代码保持纯净,即不要包含项目开发工具生成的文件,或者项目编译后的临时文件.但是,当我们使用git status查看工作区状态的时候,总会提示一些文件未被track.于是,我们想让git帮助我们忽略这些文件,不再提醒. 庆幸的是,git已经考虑到这点了.我们可以在项目的根目录下建立一个.gitignore的文件,该文件用来配置哪些文件或者目录不被track的.规则很简单,就在该文件中,写下你不想被track的文件

  • 详解phpmyadmin相关配置与错误解决

    详解phpmyadmin相关配置与错误解决 缺少mcrypt扩展 sudo apt-get install php5-mcrypt sudo php5enmod mcrypt 检查:/etc/php5/apache2/conf.d/ /etc/php5/mods-available/ 中是否有mcrypt文件 sudo service apache2 restart 开启 任意服务器登陆(访问远程服务器) 在配置文件`etc/phpmyadmin/library/config.default.p

  • 详解 hibernate mapping配置

    详解 hibernate mapping配置 每个hibernate只会启动的时候引入一个文件,那就是:hibernate.cfg.xml mapping需要我们在hibernate中引入, <mapping resource="com/hibernate/test/hibernate_IP.xml"/> <mapping class="com.hibernate.test.Student"/> 代码片段: <?xml version=

随机推荐