makefile.mk

#makefile.mk 公共头文件
ifndef TARGET
# /root/make/src/test_include
# notdir
TARGET:=$(notdir $(shell pwd)) #test_include
endif
CXXFLAGS:=$(CXXFLAGS) -g -std=c++11 -Iinclude#g++ -c 编译 自动推导
LDFLAGS:=$(LDFLAGS) #链接 可用于自动推导
LDLIBS:=$(LDLIBS) -lpthread #链接库 用于自动推导
#输出路径 /usr/bin /usr/lib /usr/include
OUT:=/usr SRCS:=$(wildcard *.cpp *.cc *.c) #test_include.cpp testcpp.cc testc.c
OBJS:=$(patsubst %.cpp,%.o,$(SRCS)) #test_include.o testcpp.cc testc.c
OBJS:=$(patsubst %.cc,%.o,$(OBJS))
OBJS:=$(patsubst %.c,%.o,$(OBJS)) #test_include.o testcpp.o testc.o #区分动态库 静态库 和执行程序
ifeq ($(LIBTYPE),.so) #动态库 $(strip $(TARGET)) 去掉前后空格\t
TARGET:=lib$(strip $(TARGET)).so
LDLIBS:=$(LDLIBS) -shared
CXXFLAGS:=$(CXXFLAGS) -fPIC
endif
ifeq ($(LIBTYPE),.a) #静态库
TARGET:=lib$(strip $(TARGET)).a
endif #启动脚本
STARTSH=start_$(TARGET)
#停止脚本
STOPSH=stop_$(TARGET) # $(1) TARGET ,$(2) OUT
define Install
@echo "begin install "$(1)
-mkdir -p $(2)
cp $(1) $(2)
@echo "end install "$(1)
endef #生成启动停止脚本,并安装到$(OUT)
# $(1) TARGET ,$(2) OUT,$(3) $PARAS
define InstallSH
@echo "begin make start shell"
echo "nohup $(1) $(3) &" > $(STARTSH)
chmod +x $(STARTSH)
cp $(STARTSH) $(2)
@echo "end make start shell" @echo "begin make stop shell"
echo killall $(1) >$(STOPSH)
cp $(STOPSH) $(2)
@echo "end make stop shell"
endef
all:depend $(TARGET)
depend:
@$(CXX) $(CXXFLAGS) -MM $(SRCS) >.depend
-include .depend #目标生成
$(TARGET):$(OBJS)
ifeq ($(LIBTYPE),.a) #静态库
$(AR) -cvr $@ $^
else
$(CXX) $(CXXFLAGS) $(LDFLAGS) $^ -o $@ $(LDLIBS)
endif #安装程序和库
install:$(TARGET)
ifdef LIBTYPE
$(call Install,$(TARGET),$(OUT)/lib)
$(call Install,*.h,$(OUT)/include)
else
$(call Install,$(TARGET),$(OUT)/bin)
$(call InstallSH,$(TARGET),$(OUT)/bin)
endif #卸载程序和库
uninstall:clean
ifndef LIBTYPE
-$(STOPSH)
$(RM) $(OUT)/bin/$(TARGET)
$(RM) $(OUT)/bin/$(STARTSH)
$(RM) $(OUT)/bin/$(STOPSH)
else
$(RM) $(OUT)/lib/$(TARGET)
endif #rm -r test.o test
#目标清理
clean:
$(RM) $(OBJS) $(TARGET) .depend .PHONY: clean uninstall install all depend #伪目标 没有对应的文件

makefile

#sCXXFLAGS:=-Iinclude
# LDFLAGS:=-L../xthread -L../xcom
# LDLIBS:=-lxthread -lxcom
include makefile.mk #统一的makefile头

tasks.json

{
"tasks": [
{
"label": "build_debug", // 任务名称,调试时可以指定不用任务进行处理
"type": "shell", // [shell, process], 定义任务作为作为进程运行还是在shell中作为命令运行; (测试没看出啥区别...)
"command": "make all", // 要执行的命令,可以是外部程序或者是shell命令。这里使用make编译命令
"problemMatcher": [ // 要使用的问题匹配程序。可以是一个字符串或一个问题匹配程序定义,也可以是一个字符串数组和多个问题匹配程序。
"$gcc"
],
"group": { // 定义此任务属于的执行组。它支持 "build" 以将其添加到生成组,也支持 "test" 以将其添加到测试组。
"kind": "build",
"isDefault": true
},
"presentation": { // 配置用于显示任务输出并读取其输入的面板
"echo": true, // 控制是否将执行的命令显示到面板中。默认值为“true”。
"reveal": "always", // 控制运行任务的终端是否显示。可按选项 "revealProblems" 进行替代。默认设置为“始终”。
"focus": false, // 控制面板是否获取焦点。默认值为“false”。如果设置为“true”,面板也会显示。
"panel": "shared", // 控制是否在任务间共享面板。同一个任务使用相同面板还是每次运行时新创建一个面板。
"showReuseMessage": true, // 控制是否显示“终端将被任务重用,按任意键关闭”提示
"clear": false // 运行前清屏
}
},
{
"label": "build_release",
"type": "shell",
"command": "make all",
"args": ["CFLAGS = -O2"], // 编译参数, 替换makefile中让CFLAGS字段
"dependsOn":["build_clean"], // 指定依赖让task, 即会先执行build_clean,然后再执行build_release
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
}
},
{
"label": "build_clean",
"type": "shell",
"command": "make",
"args": ["clean"], // 相当于执行 make clean命令
"problemMatcher": [
"$gcc"
],
"group": {
"kind": "build",
"isDefault": true
}
}
],
"version": "2.0.0"
}

launch.json

{
// 使用 IntelliSense 了解相关属性。
// 悬停以查看现有属性的描述。
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [ {
"name": "(gdb) Lauch", // 启动配置的下拉菜单中显示的名称
"type": "cppdbg",
"request": "launch",
"program": "${workspaceFolder}/Demo1", // 将要进行调试的程序的路径, workspaceFolder指当前工作目录(即vscode打开的目录:hello),main指的是makefile编译后目标码(可执行程序)的名字
"args": [], // 程序启动的参数
"stopAtEntry": false, // 设置true时,程序将暂停在程序入口处, 即main()的第一个{位置
"cwd": "${workspaceFolder}", // 调试时的工作目录
"environment": [],
"externalConsole": false, // 调试时,是否显示控制台串口
"MIMode": "gdb", // 调试命令
"setupCommands": [
{
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": true
},
{
"description": "将反汇编风格设置为 Intel",
"text": "-gdb-set disassembly-flavor intel",
"ignoreFailures": true
}
],
"preLaunchTask": "build_debug", // 使用哪个任务进行编译,需要指定tasks.json中的一个,这里选择用build_debug任务进行编译
"miDebuggerPath": "/usr/bin/gdb" // 调试命令的路径
}
]
}

vscode 开发c++的更多相关文章

  1. .Net Core Linux centos7行—vscode开发,linux部署运行

    前面搭建好啦linux运行环境,下面搭建windows下的开发环境.并完成调试 参考地址:https://www.microsoft.com/net/core#windows. 按照步骤来就好.安装. ...

  2. vscode 开发.net core 从安装到部署 教程详解

    一:环境准备: windows系统需要 win7 sp1 / windows 8  / windows 2008 r2 sp1 / windows10: 其他版本的windows系统在安装.NET C ...

  3. 用VSCode开发一个基于asp.net core 2.0/sql server linux(docker)/ng5/bs4的项目(1)

    最近使用vscode比较多. 学习了一下如何在mac上使用vscode开发asp.netcore项目. 这里是我写的关于vscode的一篇文章: https://www.cnblogs.com/cgz ...

  4. 用VSCode开发一个基于asp.net core 2.0/sql server linux(docker)/ng5/bs4的项目(3)

    第一部分: http://www.cnblogs.com/cgzl/p/8478993.html 第二部分: http://www.cnblogs.com/cgzl/p/8481825.html 由于 ...

  5. 使用vscode开发调试.net core应用程序并部署到Linux跨平台

    使用VS Code开发 调试.NET Core RC2应用程序,由于.NET Core 目前还处于预览版. 本文使用微软提供的示例进行开发及调试. https://github.com/aspnet/ ...

  6. vsCode 开发微信小程序插件

    用 vsCode 开发微信小程序可以配置以下插件,让开发更美好: 1. vscode weapp api 2. vscode wxml 3. vscode-wechat 4. Easy WXLESS ...

  7. 用vscode开发vue应用[转]

    https://segmentfault.com/a/1190000019055976 现在用VSCode开发Vue.js应用几乎已经是前端的标配了,但很多时候我们看到的代码混乱不堪,作为一个前端工程 ...

  8. 【.NET Core项目实战-统一认证平台】基于jackcao博客使用VSCode开发及感悟One搭建开发环境

    原博客系列文章链接:https://www.cnblogs.com/jackcao/ 金焰的世界 感谢博主无私的奉献,感谢博主幼儿班的教学 基于jackcao博客使用VsCode开发及感悟One搭建开 ...

  9. 用vscode开发vue应用

    阅读 3237 收藏 205 2019-05-02 原文链接:segmentfault.com 云服务器 1 核 2G , 9元/月 ,买十送二,99/年!!!快来上车!developer.huawe ...

  10. 使用VSCode开发Flutter

    前言 为什么使用VSCode? flutter官方推荐的编辑器有IDEA/Android Studio和VSCode, 之前开发Flutter用的IDEA, 不过IDEA始终比较重,于是换用VSCod ...

随机推荐

  1. js任务队列EventLoop

    JS 执行机制 在我们学js 的时候都知道js 是单线程的如果是多线程的话会引发一个问题在同一时间同时操作DOM 一个增加一个删除JS就不知道到底要干嘛了,所以这个语言是单线程的但是随着HTML5到来 ...

  2. 浅谈Java并发

    Java并发是比较难的知识点,难于对并发的理解.并发要从操作系统和硬件层面去理解,才会比较深入,而不单单是从编程语言的逻辑去理解. 首先对于并发要清楚的几点: 线程可能在任何时刻被切换.计算机只对硬件 ...

  3. vivo 故障定位平台的探索与实践

    作者:vivo 互联网服务器团队- Liu Xin.Yu Dan 本文基于故障定位项目的实践,围绕根因定位算法的原理进行展开介绍.鉴于算法有一定的复杂度,本文通过图文的方式进行说明,希望即使是不懂技术 ...

  4. 判断一个对象是否是数组的n个方法,typeOf不能判断引用类型对象

  5. drf-day1——web应用模式、API接口、接口测试工具postman

    目录 学习资料 一.web 应用模式 二.API接口 API概念 三.接口测试工具postman postman介绍 postman下载与使用 四.如何在浏览器中测试 学习资料 # 个人博客:http ...

  6. 【学习笔记】Http请求方法总结

    Http常用请求方法对比 请求方法 常见参数传递方式 是否幂等 说明 API举例 GET URL,注意:Http协议对URL长度没有限制,所谓的限制是浏览器和处理服务器的 幂等 用于查询 批量查询:/ ...

  7. 插入排序(CSP-J 2021 T2)

    题目:(由于题干过长直接上链接:P7910 [CSP-J 2021] 插入排序 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)) 不是打广告 又有一个新思路: 我们可以再开一个b数组 ...

  8. 线程基础知识15-StampedLock

    1 简介 StampedLock是JDK1.8中新增的一个读写锁,也是对JDK1.5中的读写锁ReentrantReadWriteLock的优化.在原先读写锁的基础上新增了一种叫乐观读(Optimis ...

  9. CentOS安装mysql、MariaDB以及更改数据库存储路径

    注意:此方法只适用于新的机器或没有重要数据库表(可随意删除)的机器安装,如需升级版本参考下方链接!!! https://www.jianshu.com/p/955ff6065935 一.安装操作 1. ...

  10. SQL 实现全字段分组,每组取一条记录,记录满足:组内时间最大,组内不同类型数量求和

    1 SELECT 2 TT.CLASS_ID AS "classId", 3 TT.TEMPLATE_ID AS "templateId" , 4 TT.MSG ...