众所周知,C++的调试是一个严肃而且严重的问题。。。 特别是在算法竞赛上,我们需要一种方法快速地找出程序bug的位置。在这个过程中,我们时常需要输出中间变量。笔者近日有幸听得大佬的经验(先膜一波大佬),在此备忘。
直接进入正题,输出中间变量的神秘语句:
#define DebugP(x) std::cout << "Line" << __LINE__ << " " << #x << "=" << x << std::endl
下面来详细阐述一下:
宏定义一个函数,为什么用宏呢?主要原因是宏可以打出变量名和行号,这对于调试中输出中间变量十分重要。
__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
于是,定义的宏就没有任何作用了。
说到这里,不得不大吼一句666
注意事项:不要在调用DebugP的时候对变量进行任何操作!错误示范:
DebugP(a++);
说到最后,不得不说一句,为什么笔者退役以后才听大佬说这个神操作。。。(抱头痛哭)
仅以此文造福所有的信竞选手!