使用VS2022开发在线远程编译部署的C++程序(图文详解)

一、先来一点C++的资源分享,意思一下。

1、c++类库源码以及其他有关资源。站点是英文的,英文不好的话可以谷歌浏览器在线翻译。http://www.cplusplus.com/

2、C++参考手册。页面有点复古,不过有中文版本的。https://zh.cppreference.com/w/cpp

3、GUNC++库,你懂的。https://gcc.gnu.org/onlinedocs/libstdc++/index.html

4、一群大佬分享的一些中文开源资源。https://github.com/jobbole/awesome-cpp-cn

二、接下来是过渡,说点题外话,纯属发牢骚,可以直接跳过去看第三节。

C/C++大概我有五六年没玩了,基本上忘了差不多。主要是入了C#这个坑(比C++多了俩+号)。刚好最近几天在休年假,今天(2021-12-15)略感有点无趣,于是下午就想着撸一下C++,试试手感,但是很久以前的VisualC++6.0这种古老的编译器肯定不太合适了,于是最开始想到了VisualStudioCode。于是先下载了MinGW,下载地址是:https://sourceforge.net/projects/mingw/

5、安装MinGW以后,把以下全部勾选上。如果遇到不晓得是干嘛的选项,一般默认也勾上,可以减少错误的概率。

6、MinGW安装以后,需要把安装根目录下的bin目录,加到环境变量的Path里面,这样控制台或者PowerShell里面就可以直接使用gcc或者g++命令进行编译了(使用编译器直接跑也可以,但是写命令感觉比较骚一点)。

Cmd命令行输入gcc-v或g++-v可以显示版本信息那些,就说明是OK的了。

7、再然后是VSCODE上面安装了C++语言环境,我安装了以下圈起来的那些。

8、然后最下面那个安装以后,可以配置运行按钮。不过我本地没配好,退而求其次,使用了VSCODE右上角的那个三角形来运行。

9、如下,点击既可编译运行。如果是多个文件路径,还需要自行配置进行链接起来。

10、同时也支持在terminal窗口使用命令进行编译。编译以后默认会生成a.exe文件,如果需要生成指定名称的文件,可以使用g++xxx.cpp指定的名称来实现。

到以上步骤以后,总感觉有点怪怪的,可能是VSCODE我还是更喜欢用来开发一些例如golang、或者前端等的东西比较上手。开发C++总感觉不太上手,也不晓得怎么跨平台发布(实力有限,搞不定)。于是,我最终换成了VisualStudio2022这个宇宙最强IDE来进行跨平台的开发。

三、以下开始是正文,使用VS2022 开发远程跨平台的C++程序。

11、首先,我之前申请了一个TX云服务器(CentOS8.0系统),这下算是派上用场了。先远程过去下点东西。远程linux控制台的命令是ssh用户名@ip地址

12、远程过去以后,需要安装sshserver。命令:yuminstall-yopensslopenssh-server。安装它的作用是让它可以被VS2022编译器远程访问到。

13、进入到ssh的配置文件下做些修改。修改文件:/etc/ssh/sshd_config

14、更改一些信息,将PermitRootLogin,RSAAuthentication,PubkeyAuthentication的注释打开并且设置为yes。如果没有找到对应的,也可以直接新增。

15、启动sshd服务,并且设置为开机启动。命令分别是:

systemctlstartsshd.service

systemctlenablesshd.service

16、然后安装gdb服务。安装命令:yum-yinstallgdbgdb-gdbserver

gdb是linux下常用的调试器,不安装可能导致编译失败或者没法编译。

17、然后是安装g++工具,先检查下g++有没有安装。有些linux系统可能会自带gcc和g++,没有自带咱们就自己安装个好了。

18、通过命令安装gcc和g++。安装命令:

sudoyum-yinstallgccgcc-c++kernel-devel

19、安装完毕以后,查看g++版本。显示版本号就代表安装成功了,和在Windows上安装MinGW以后的类似。不过此处的版本是4.x,和win上面的版本对比下貌似老了点,不过暂时不影响,如果不适用C++的新特性应该问题不大。如果需要使用一些新特性,就需要独立安装高版本的g++工具了,这个大佬们可以自行研究。

20、接下来做个实验。首先要对VS2022做一点配置。配置一个可以提供远程访问的东西。工具-选项-跨平台-连接管理器里面,添加一个远程访问的连接。

主机名=ip地址;端口默认22

21、设置完成以后。就可以开始写代码测试了。先使用VS2022新建一个c++项目。此处我使用的是控制台项目。

22、一些配置,在项目的右键属性里面,可以看到配置的远程连接地址被加进去了。并且在远程根目录下,设置了一个文件夹,叫cpp_projects,设置以后,编译以后的代码和文件都会被丢到这个文件夹下。

23、执行程序的地方,默认也会出现上面配置的远程Linux服务器的IP地址。

24、执行程序,由于没有断电或其他中断操作,所以执行以后成功的话,会直接变回还没有启动的样子。但是此时,运行完毕以后(编译完毕以后),会发现刚才配置的文件夹确实出现在了根目录下。咱们可以在对应的debug里面进行直接运行该程序,打印出了咱们在VS2022上面开发的打印内容。

25、增加头文件试一下效果,把头部信息丢到hello.h里面。

26、同时新增了控制台输入,用来测试输入,通过指针输出出来。然后运行程序。运行成功,会显示部署成功字样,不过一闪而过,容易忽略。

27、远程linux系统上面,试一下效果。

28、瞅一下编译生成的中间文件,Obj文件夹下的xxx.o文件,貌似有点尴尬,乱码了,那就不科普了,大佬们自行玩玩。

29、同样的,在linux系统上面,也可以使用g++命令进行编译。因为代码会被自动远程拷贝过来,所以也可以直接在这上面编译和运行。

30、上面代码带有输入语句,所以控制台会被中断进行停留,此刻还可以在VS上面看到远程调用Linux控制台窗口的输出。不过只要中断没了,就立马程序也就执行完了。

以上就是本篇文章的全部内容,感谢大佬们的围观。

到此这篇关于使用VS2022开发在线远程编译部署的C++程序(图文详解)的文章就介绍到这了,更多相关VS2022在线远程编译部署C++程序内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Microsoft Visual C++ 程序的部署方法

    1. 用Microsoft Visual C++ 6.0编译的程序,或者发布在Windows 2000/NT/ME/98 系统单纯通过拷贝MSVCRxx.DLL文件到应用程序目录或system32目录即可 2. 用Visual Studio 2005以上编译的程序,且发布在Windows XP及以上系统为了减少DLL引发的配置问题(DLL hell),C和C++运行时由并行 (Side-by-Side) 程序集实现,单纯通过拷贝MSVCRxx.DLL并不足以在非开发环境正常运行程序,必须通过一个

  • VS2022远程调试工具的使用方法

    在工作中有时候需要在服务器的环境下远程调试,例如调试微信相关服务的时候. 1. 下载远程调试工具 网址:https://visualstudio.microsoft.com/zh-hans/downloads/ 下载后直接安装至完成. 启动Remote Debugger: 如果只是短时间测试,可以选择无身份验证,为了安全,工具自动设置了空闲时间,即多久没有操作会自动关闭此功能. 2.新建测试项目 建了一个简单的HelloWorld项目,简单几句代码,加上断点. 发布debug到远程服务器. 双击

  • 使用VS2022开发在线远程编译部署的C++程序(图文详解)

    一.先来一点C++的资源分享,意思一下. 1.c++类库源码以及其他有关资源.站点是英文的,英文不好的话可以谷歌浏览器在线翻译.http://www.cplusplus.com/ 2.C++参考手册.页面有点复古,不过有中文版本的.https://zh.cppreference.com/w/cpp 3.GUNC++库,你懂的.https://gcc.gnu.org/onlinedocs/libstdc++/index.html 4.一群大佬分享的一些中文开源资源.https://github.c

  • Pycharm内置终端及远程SSH工具的使用教程图文详解

    1.主题 如何使用Pycahrm内置终端以及远程SSH工具. 2.准备工作 Pycharm版本为3.0或更高 连接SSH服务器 3.使用SSH客户端 4.开启连接 选择Tools | Start SSH Session...的主菜单命令,单击Edit credentials: 5.提供连接信息 在Session对话框中输入建立连接所需相关信息: 6.建立连接 单击OK,连接开始: 7.SSH会话功能 运行命令.粘贴复制.浏览历史命令-- 8.远程SSH外部工具的作用 定义一个外部工具用来脱机运行

  • 微信公众平台开发教程①获取用户Openid及个人信息图文详解

    本文实例讲述了微信公众平台开发获取用户Openid及个人信息.分享给大家供大家参考,具体如下: 前言: 初次尝试微信公众号的开发,对于学习方法的探索都是来源于网上的博客.问答,对于参差不齐的信息,自己也是有苦说不出,抽出一点时间写点文章,既是对自己的学习总结,也希望给予同是菜鸟的学渣一点帮助 背景介绍: 我需要用户接收微信分享的链接后,点击进入给参加活动的用户[点赞],然后需要后台获取该微信用户的 openid 作为唯一的标记信息,以便保证该用户下次进入后进行数据库的比对,直接提取其对应的操作信

  • 微信公众平台开发教程④ ThinkPHP框架下微信支付功能图文详解

    本文实例讲述了ThinkPHP框架下微信支付功能.分享给大家供大家参考,具体如下: 声明:原文主要摘自白俊遥博客 ,部分内容针对个人事例已作修改,主要用于自己的参考,欢迎指正. 注意:微信公众号支付,强烈建议使用外网可访问的链接测试,否则即便代码正确也无法调出支付界面,可使用草料二维码生成可扫描图片,也可直接在微信中输入网址. 使用框架:ThinkPHP 3.2.3 一.微信公众平台信息配置 1).进入微信公众平台 由左侧的"微信支付"进入配置界面,添加或修改正确的支付授权目录,注意该

  • Docker部署nginx实现过程图文详解

    1.下载nginx [root@localhost my.Shells]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE docker.io/redis latest 1e70071f4af4 6 weeks ago 106.7 MB [root@localhost my.Shells]# docker pull nginx //下载nginx Using default tag: latest Trying to pull reposit

  • java进行远程部署与调试及原理详解

    这篇文章主要介绍了java进行远程部署与调试及原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 远程调试,特别是当你在本地开发的时候,你需要调试服务器上的程序时,远程调试就显得非常有用. JAVA 支持调试功能,本身提供了一个简单的调试工具JDB,支持设置断点及线程级的调试同时,不同的JVM通过接口的协议联系,本地的Java文件在远程JVM建立联系和通信.此篇是Intellij IDEA远程调试的教程汇总和原理解释,知其然而又知其所以然.

  • Windows系统中搭建Go语言开发环境图文详解

    目录 1.Go语言简介 2.安装Git 3.Go 工具链(编译器)安装 3.1.环境变量GOROOT 3.2.环境变量GOPATH 3.3.Go常用命令 4.包管理 4.1.go module 4.2.gopm 5.编写Go语言代码的IDE或编辑工具 5.1.基于VSCode的Go开发环境 5.1.1.安装VSCode 5.1.2.安装插件 5.1.3.常用配置 5.2.GoLand 5.3.Vim 5.4.其他Go代码编写工具 6.Go语言学习资料分享 本文详细讲述如何在 Windows 系统

  • golang项目如何上线部署到Linu服务器(方法详解)

    Go作为Google2009年推出的语言,其被设计成一门应用于搭载 Web 服务器,存储集群或类似用途的巨型中央服务器的系统编程语言. 对于高性能分布式系统领域而言,Go 语言无疑比大多数其它语言有着更高的开发效率.它提供了海量并行的支持,这对于游戏服务端的开发而言是再好不过了. 到现在Go的开发已经是完全开放的,并且拥有一个活跃的社区. 下面看下golang项目如何上线部署到Linu服务器上. windows服务器 先本地编译 go build main.go 编译后会在同级目录生成可执行文件

  • 关于在IDEA热部署插件JRebel使用问题详解

    问题描述: 在日常开发工作中,代码出现问题时往往要不停的修改测试验证其正确性.每一次修改代码都需要重启项目,十分耗时,对于企业大型项目来说重启一次项目的时间够你去喝杯咖啡了.为了减少项目重启的时间所以来介绍这款插件工具JRebel JRebel介绍: JRebel是一款JVM插件,它使得Java代码修改后不用重启项目,立即生效.IDEA上原生是不支持热部署的,一般更新了 Java 文件后要手动重启项目,才能生效,浪费时间浪费生命. 目前对于idea热部署最好的解决方案就是安装JRebel插件 s

  • Vue项目webpack打包部署到服务器的实例详解

    Vue项目webpack打包部署到服务器 这篇博文主要说的就是我今天遇到的问题,而且在经过我的询问,好多人在打包部署的时候都遇到了一些问题,下面就来说下,如何将Vue项目放置在服务器上,这里以Tomcat为例. 必须要配置的就是/config/index.js 在vue-cli webpack的模板下的/config/index.js,我们可以看到assetsPublicPath这个键,并且这个东西还出现了两次,我第一次打包的时候,只是修改了最下面的assetsPublicPath,将它从'/'

随机推荐