1 Star 0 Fork 115

fangcongss / CPlusPlusThings

forked from Yj / CPlusPlusThings 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
C++的Debug工具dbg-macro.md 1.67 KB
一键复制 编辑 原始数据 按行查看 历史
ChungZH 提交于 2020-03-03 12:39 . Create C++的Debug工具dbg-macro.md

C++ 的 debug 工具:dbg-macro

打日志是 C++ 开发中必不可少的一种 debug 方式,dbg-macro 受 Rust 语言中 的 dbg 启发,提供比 printfstd::cout 更好的宏函数。主要有如下特点:

  • 美观的彩色输出(当输出不是交互式终端时,颜色将自动禁用)
  • 兼容 C++11,并且是 header-only
  • 支持基础类型和 STL 容器类型的输出
  • 可以输出文件名、行号、函数名和原始表达式

例如下面的代码:

#include <vector>
#include <dbg.h>

// You can use "dbg(..)" in expressions:
int factorial(int n) {
  if (dbg(n <= 1)) {
    return dbg(1);
  } else {
    return dbg(n * factorial(n - 1));
  }
}

int main() {
  std::string message = "hello";
  dbg(message);  // [example.cpp:15 (main)] message = "hello" (std::string)

  const int a = 2;
  const int b = dbg(3 * a) + 1;  // [example.cpp:18 (main)] 3 * a = 6 (int)

  std::vector<int> numbers{b, 13, 42};
  dbg(numbers);  // [example.cpp:21 (main)] numbers = {7, 13, 42} (size: 3) (std::vector<int>)

  dbg("this line is executed");  // [example.cpp:23 (main)] this line is executed

  factorial(4);

  return 0;
}

效果如下:

安装

git clone https://github.com/sharkdp/dbg-macro
sudo ln -s $(readlink -f dbg-macro/dbg.h) /usr/include/dbg.h

这样,你就可以在任何地方使用 dbg.h 了。

在 Arch Linux 上

yay -S dbg-macro

使用 vcpkg

vcpkg install dbg-macro

更多内容详见 官方文档

C++
1
https://gitee.com/fangcongss/CPlusPlusThings.git
git@gitee.com:fangcongss/CPlusPlusThings.git
fangcongss
CPlusPlusThings
CPlusPlusThings
master

搜索帮助