vscode下载安装这些就略过了,从插件安装和配置文件开始介绍
参考文章:https://zhuanlan.zhihu.com/p/112125338
上面这个整体写的不错,不过一些细节部分个人觉的存在一些问题,也比较容易出错,下面写一个更清晰的。
在远程linux中安装g++和cmake工具,方法网上有很多。
给出个参考:
yum -y install gcc g++ make
这里有一个比较全的:https://zhuanlan.zhihu.com/p/68577071
但如果只是想简单的使用,也没必要看那么多。
安装完Remote-SSH插件之后,vscode左边会出现一个远程资源管理器的小图标,点进去,再点一下小齿轮,出现两个配置文件,选第一个,个人用户配置
然后按照这个格式编辑一下即可
Host <远程主机名称1>
HostName <远程主机1 IP>
User <用户名1>
Port
IdentityFile <本机SSH私钥路径>
ForwardAgent yes
Host root16g
HostName 172.28.93.167
User root
Host test16g
HostName 172.28.93.167
User test
Host root8g
HostName 172.28.93.177
User root
然后选择对应的链接,输入密码即可。
demo项目结构如下:
demo/
|---src/
| |---add.h
| |---add.cpp
|---main.cpp
|---CMakeLists.txt
代码简单写一下
// add.h
#ifndef SRC_ADD_H
#define SRC_ADD_H
int add(int a, int b);
#endif
//add.cpp
#include"add.h"
int add(int a, int b){
return a + b;
}
// main.cpp
#include
#include"src/add.h"
int main() {
int a = 1;
int b = 2;
printf("%d + %d = %d\n", a, b, add(a, b));
}
CMakeLists.txt内容:
# 指定cmake最低版本
cmake_minimum_required(VERSION 3.21)
# 定义项目名称
project(demo)
# 指定-std=c++11
set(CMAKE_CXX_STANDARD 11)
# 找当前目录下所有源文件, 保存到DIR_SRCS中
aux_source_directory(. DIR_SRCS)
aux_source_directory(./src DIR_SRC_SRCS)
# 指定生成目标
add_executable(main ${DIR_SRCS} ${DIR_SRC_SRCS})
很明显,正常来说,在demo目录中,执行cmake .
命令获得makefile文件,之后执行make
命令编译出可执行文件main。
如何通过vscode执行以上步骤呢?
一个vscode项目中的个性化配置信息都会被vscode保存在项目中的.vscode目录中,以demo项目举例,现在这个项目的文件结构应该是
demo/
|---.vscode/
|---src/
| |---add.h
| |---add.cpp
|---main.cpp
|---CMakeLists.txt
其中.vscode目录下可能没什么东西,因为我们还什么都没配置呢,只有我们配置之后,vscode才会在该目录下创建一个个性化配置的文件。
c_cpp_properties.json文件是c/c++扩展的配置文件,可以配置一些包含路径,编译器路径,编译器参数等信息。
通过Ctrl + Shift + P
快捷键打开命令窗口,首先配置c/c++扩展,通过(UI)和(JSON)都可以,UI就是可视化的配置文件,这里用JSON配置,比较好写
选择c_cpp_properties.json文件,vscode会自动在.vscode目录下创建对应的文件
文件内容是:
{
"configurations": [
{
"name": "Linux",
"includePath": [
"${workspaceFolder}/**", //默认的目录,自动生成的
"/usr/include/**" // 需要自行添加的本地头文件目录
],
"defines": [],
"compilerPath": "/usr/bin/gcc",
"cStandard": "c11",
"cppStandard": "c++14",
"intelliSenseMode": "linux-gcc-x64",
"configurationProvider": "ms-vscode.makefile-tools"
}
],
"version": 4
}
文件内容比较简单,就是定义一些编译信息(其实如果使用cmake的话,不会用到的,这些信息可以看成写代码时vscode的语法补全等操作,不涉及编译等信息,因为我们的编译配置都会在CMakeLists.txt中配置)。
launch.json文件是告知vscode在启动调试时如何启动程序,通过vscode右上角的那个小齿轮(添加调试配置)可以自动生成该文件,并且会自动生成一些配置信息。
我们可以改一下名字name,改一下prgram和cwd,然后就是preLaunchTask。
{
"configurations": [
{
"name": "(gdb)Launch",
"type": "cppdbg",
"request": "launch",
"program": "${fileDirname}/build/${fileBasenameNoExtension}", // 程序路径 我这里是build下
"args": [],
"stopAtEntry": false,
"cwd": "${fileDirname}/build/", // 工作目录
"environment": [],
"externalConsole": false,
"MIMode": "gdb",
"preLaunchTask": "build debug", // 使用build debug预处理方法
"miDebuggerPath": "/usr/bin/gdb",
"setupCommands": [
{
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": true
},
{
"description": "将反汇编风格设置为 Intel",
"text": "-gdb-set disassembly-flavor intel",
"ignoreFailures": true
}
],
},
],
"version": "2.0.0"
}
注意几个点:
tasks.json文件就是launch.json中prelaunchtask字段中的预处理或后处理配置。
这些任务可以在编译之前或之后执行,非常方便。
我们在这里实现一下launch中定义的build debug任务
{
"tasks": [
{
"label": "build debug",
"type": "shell",
"linux":{
// 配置每次编译之前都会执行一次cmake
"command": "mkdir -p build && cmake -B build -DCMAKE_BUILD_TYPE=Debug && cd build && make",
}
},
],
"version": "2.0.0"
}
内容很简单,每次编译之前都会执行一次cmake系列的命令。
拆解出来就是
cmake -B build -DCMAKE_BUILD_TYPE=Debug
指定build目录是生成文件和目标文件的目录,并指定编译类型为debug以上,配置信息已经完成了,接下来就可以启动调试来测试了。
在main下面打上断点,启动调试,选择定义的任务 (gdb) Launch
目录结构会变为:
demo/
|---.vscode/
|---build/
|---|---src/
|---|---CMakeList.txt
|---|---main
|---src/
| |---add.h
| |---add.cpp
|---main.cpp
|---CMakeLists.txt
可以看到可视化的调试信息:
因为我用的远程服务器设计保密,屏蔽了系统的截图,所以就拍个照片放上了。
可能是ssh设置的问题,执行vim /etc/ssh/sshd_config
打开ssh的服务端配置文件,找到里面的PermitRootLogin参数,看看是yes还是no。这个可能会导致无法通过root用户登录。
如果一直ssh连不上,可能时服务器的ssh设置问题。打开vim /etc/ssh/sshd_config
文件,看里面的AllowTcpForwarding字段是yes还是no。这个可能导致一直无法通过tcp链接。
可能是出错了,或者是写的慢。
可以查看日志输出判断,
我是装完插件之后发现,没有用,vscode也不会在项目目录中自动生成 .vscode 这个配置目录。
重装重启解决99%的问题(
记得卸载的时候删干净,不是一个unins就完了,个人配置也删掉。
然后就能用了,很神奇,也不知道为啥。