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. vulnhub靶场之GROTESQUE: 3.0.1

    准备: 攻击机:虚拟机kali.本机win10. 靶机:Grotesque: 3.0.1,下载地址:https://download.vulnhub.com/grotesque/grotesque3. ...

  2. [OpenCV实战]52 在OpenCV中使用颜色直方图

    颜色直方图是一种常见的图像特征,顾名思义颜色直方图就是用来反映图像颜色组成分布的直方图.颜色直方图的横轴表示像素值或像素值范围,纵轴表示该像素值范围内像素点的个数或出现频率.颜色直方图属于计算机视觉中 ...

  3. JavaScript 图像压缩

    JavaScript 可以使用类似于 canvas 和 web workers 来实现图像压缩. 使用 canvas,可以将图像绘制到 canvas 上,然后使用 canvas 提供的 toBlob( ...

  4. C++Day12 虚拟继承内存布局测试

    测试一.虚继承与继承的区别 1.1 单个继承,不带虚函数 1>class B size(8): 1> +--- 1> 0 | +--- (base class A) 1> 0 ...

  5. 对象的变为私有方法不可改动 seal freeze

  6. dapr入门与本地托管模式尝试

    1 简介 Dapr是一个可移植的.事件驱动的运行时,它使任何开发人员能够轻松构建出弹性的.无状态和有状态的应用程序,并可运行在云平台或边缘计算中,它同时也支持多种编程语言和开发框架.Dapr支持的语言 ...

  7. MRS_MounRiver安装与驱动相关问题汇总

    解决问题如下: MounRiver下载与安装 若MounRiver某些功能不全或插件没安装 MounRiver下载与安装 MRS官网下载:http://www.mounriver.com/downlo ...

  8. 10月31日ATM编写逻辑描述

    目录 ATM逻辑描述 三层框架简介 1.第一层(src.py) 2.第二层(interface文件夹下内容) 3.第三层(db_hanlder) 启动函数 用户注册功能 用户登录 common中的小功 ...

  9. ATM项目开发

    目录 一.项目开发流程 1.项目需求分析: 2.项目架构设计: 3.项目分组开发: 4.项目提交测试: 5.项目交付上线: 二.项目需求分析 1.主题 2.项目核心 3.项目需求: 4.从需求中提炼出 ...

  10. java应用定位高cpu占用几步操作

    1.top获取高cpu占用的pid,如266202.查看pid的线程情况, top -H -p 266203.把cpu高占用的线程号转为16进制,printf "%x" 26652 ...