From:https://blog.csdn.net/mumufan05/article/details/80094637

上一篇简单介绍了vs2017新建一个linux的工程,本编将介绍一下如何管理已有的makefile工程,如果你想了解新建工程该如何操作,请点击下面的连接:

https://blog.csdn.net/mumufan05/article/details/80093732

本篇以unzip的源码工程为例进行介绍,将unzip的源码解压后我们没有在源码的根目录下找到makefile,需要手动将unix目录下的Makefile拷贝到根目录下,并在终端执行“make unzip”进行编译。

如果您的工程还没有makefile,请根据您的工程结构,搞出一个makefile,现在我假设您已经准备好了makefile了,好,我们开始。

首先,我们要做的第一件事就是想办法让你的linux和Windows进行文件共享,用什么方式不重要,只要能让你的Windows能够想访问本地文件一样去访问linux上的文件就可以,关于这一点,请您自行百度。

然后,请去https://github.com/robotdad/vclinux这个页面下载vclinux,这是微软官方提供的shell脚本,可以根据makefile生成vs的工程文件。

下载完成后放到linux上进行解压,找到bash目录中的两个脚本文件,并执行这两个脚本,命令格式如下

$ ./genvcxproj.sh 工程目录 xxx.vcxproj
$ ./genfilters.sh 工程目录 xxx.vcxproj.filters

具体内容相见压缩包中的README.md

执行完上面两条命令,就会在工程目录下生成vs的工程文件,用vs打开这个工程,然后在打开工程是属性页面,点击常规,在右边找到远程生成根目录,修改为linux工程目录所在的目录,注意是工程目录所在的目录,而不是工程文件所在的目录,比如我将unzip.tar.gz放在了/home/user/work目录,解压后会在该目录下多出来一个unzip目录用来存放unzip的工程文件,我们这里要修改的目录是/home/user/work,而不是/home/user/work/unzip,这里一定要注意,如下图

然后单击远程生成选项,在右面配置程序的生成命令,清理命令,重新生成命令,如下图

最后,我们再配置一下调试选项,点击调试,在右边配置可执行程序的路径,运行参数,工作目录等,如下图所示

至此,所有的配置都完成了,以上所有配置内容都可以根据自己的习惯进行相应的修改,调试的时候如果涉及到终端的输入输出,可以在调试菜单中找到linux控制台,使用微软提供的那个简陋的模拟终端。

用了两天,感觉这次vs2017提供的linux程序开发,完全符合微软东西的特点:好用吗?好用,真TM好用,功能很强大,用的爽吗?不爽,非常的不爽,因为超级卡。每次启动编译和启动调试的时候都非常的慢,不过这个慢也是可以理解的,毕竟编译和调试都是在远程linux上进行的。不过这次的2017可以模块安装,完全可以根据自己的需要进行定制,倒是没有以前版本那么臃肿了。

更多内容详见微软的官方博客文章https://blogs.msdn.microsoft.com/vcblog/2016/03/30/visual-c-for-linux-development/

=====================================================================

用了一段时间,发现启动编译和启动调试都非常慢是Visual Assist X的锅,把插件禁掉就很快了。但对于用习惯Visual Assist X插件的用户来说,把它禁掉也是一件十分蛋疼的事,所以就看个人的取舍了。

大杀器:VS2017 查看或调试liunx代码(转载)的更多相关文章

  1. 使用docker-compose 大杀器来部署服务 上

    使用docker-compose 大杀器来部署服务 上 我们都听过或者用过 docker,然而使用方式却是仅仅用手动的方式,这样去操作 docker 还是很原始. 好吧,可能在小白的眼中噼里啪啦的对着 ...

  2. 使用docker-compose 大杀器来部署服务 上(转)

    使用docker-compose 大杀器来部署服务 上 我们都听过或者用过 docker,然而使用方式却是仅仅用手动的方式,这样去操作 docker 还是很原始. 好吧,可能在小白的眼中噼里啪啦的对着 ...

  3. [转]使用docker-compose 大杀器来部署服务 上

    本文转自:https://www.cnblogs.com/neptunemoon/p/6512121.html 使用docker-compose 大杀器来部署服务 上 我们都听过或者用过 docker ...

  4. 使用docker-compose 大杀器来部署服务

    使用docker-compose 大杀器来部署服务 上 我们都听过或者用过 docker,然而使用方式却是仅仅用手动的方式,这样去操作 docker 还是很原始. 好吧,可能在小白的眼中噼里啪啦的对着 ...

  5. Postgresql-模糊匹配大杀器

    # Postgresql-模糊匹配大杀器 ## 问题背景 随着pg越来越强大,abase目前已经升级到5.0(postgresql10.4),目前abase5.0继承了全文检索插件(zhparser) ...

  6. [NewLife.XCode]反向工程(自动建表建库大杀器)

    NewLife.XCode是一个有10多年历史的开源数据中间件,支持nfx/netstandard,由新生命团队(2002~2019)开发完成并维护至今,以下简称XCode. 整个系列教程会大量结合示 ...

  7. postgres模糊匹配大杀器

    ArteryBase-模糊匹配大杀器 问题背景 随着pg越来越强大,abase目前已经升级到5.0(postgresql10.4),目前abase5.0继承了全文检索插件(zhparser),使用全文 ...

  8. 一文读懂机器学习大杀器XGBoost原理

    http://blog.itpub.net/31542119/viewspace-2199549/ XGBoost是boosting算法的其中一种.Boosting算法的思想是将许多弱分类器集成在一起 ...

  9. 离群点检测与序列数据异常检测以及异常检测大杀器-iForest

    1. 异常检测简介 异常检测,它的任务是发现与大部分其他对象不同的对象,我们称为异常对象.异常检测算法已经广泛应用于电信.互联网和信用卡的诈骗检测.贷款审批.电子商务.网络入侵和天气预报等领域.这些异 ...

随机推荐

  1. 从零开始学 Web 系列教程

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新…… github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:http:/ ...

  2. 新生命Redis组件(.Net Core 开源)

    NewLife.Redis 是一个Redis客户端组件,以高性能处理大数据实时计算为目标.Redis协议基础实现Redis/RedisClient位于X组件,本库为扩展实现,主要增加列表结构.哈希结构 ...

  3. How Tomcat works — 一、怎样阅读源码

    在编程的道路上,通过阅读优秀的代码来提升自己是很好的办法.一直想阅读一些开源项目,可是没有合适的机会开始.最近做项目的时候用到了shiro,需要做集群的session共享,经过查找发现tomcat的s ...

  4. Java BIO、NIO、AIO

    同步与异步 同步与异步的概念, 关注的是 消息通信机制 同步是指发出一个请求, 在没有得到结果之前该请求就不返回结果, 请求返回时, 也就得到结果了. 比如洗衣服, 把衣服放在洗衣机里, 没有洗好之前 ...

  5. flask中接收post传递数组方法

    list = request.form.getlist("表单名")

  6. 使用ZeroBrane Studio调试Openresty lua脚本

    介绍 ZeroBraneStudio 作为轻量级.跨平台的Lua IDE,已被广泛用来调试各种Lua引擎游戏框架.Openresty.Wireshark脚本等等. Openresty 是一个建立在Ng ...

  7. Tomcat8源码笔记(八)明白Tomcat怎么部署webapps下项目

    以前没想过这么个问题:Tomcat怎么处理webapps下项目,并且我访问浏览器ip: port/项目名/请求路径,以SSM为例,Tomcat怎么就能将请求找到项目呢,项目还是个文件夹类型的? Tom ...

  8. MySQL中字段字符集不同导致索引不能命中

    今天写了一个sql,其中涉及的表中的数据量都差不多为50w左右,查询发现用了8s.这个只是测试服上数据,放到正式服上,肯定一运行就挂了. SELECT Orders. NO, GuidNo, Orde ...

  9. 三大主流软件负载均衡器对比(LVS VS Nginx VS Haproxy)

    LVS:1.抗负载能力强.抗负载能力强.性能高,能达到F5硬件的60%:对内存和cpu资源消耗比较低2.工作在网络4层,通过vrrp协议转发(仅作分发之用),具体的流量由linux内核处理,因此没有流 ...

  10. 翻译:如何向MariaDB中快速插入数据(已提交到MariaDB官方手册)

    本文为mariadb官方手册:How to Quickly Insert Data Into MariaDB的译文. 原文:https://mariadb.com/kb/en/how-to-quick ...