本文已参与「新人创作礼」活动,一起开启掘金创作之路。
众所周知,C++的调试是一个严肃而且严重的问题。。。 特别是在算法竞赛上,我们需要一种方法快速地找出程序bug的位置。在这个过程中,我们时常需要输出中间变量来观察程序对输入的运算情况。笔者近日有幸听得大佬的经验(先膜一波大佬),在此备忘。
大佬轻喷
直接进入正题,输出中间变量的神秘语句如下:
#define DebugP(x) std::cout << "Line" << __LINE__ << " " << #x << "=" << x << std::endl
下面来详细解释一下:
宏定义一个函数DebugP,为什么用宏呢?主要原因是宏可以打出变量名和行号,这对于调试中输出中间变量十分重要。
__LINE__:LINE前后均为两个下划线,用来输出此宏调用的行号。#x:输出调用的变量的变量名(好东西啊),可以很清楚的区分出不同的变量。- 中间使用了tab使得排版更加好看
- 用
cin/cout是为了输出几乎任何的变量类型
举个例子,在程序中使用的时候:
#include <bits/stdc++.h>
#define DebugP(x) std::cout << "Line" << __LINE__ << " " << #x << "=" << x << std::endl
using namespace std;
int main() {
int a, b, c;
cin >> a >> b;
DebugP(a); DebugP(b);
c = a * a + b * b;
DebugP(a); DebugP(b); DebugP(c);
cout << c << endl;
return 0;
}
如果输入为3 2,则输出会成为:
Line8 a=3
Line8 b=2
Line10 a=3
Line10 b=2
Line10 c=13
13
最厉害还在下面:如果你现在写好了程序,准备提交了,需要删除所有的调试信息,怎么办?
只需要把原来的DebugP的宏定义,改成如下的样子:
#define DebugP
于是,定义的宏就没有任何作用了。
注意事项:不要在调用DebugP的时候对变量进行任何操作!错误示范:
DebugP(a++);
祝各位信竞选手早日取得好成绩!