代码定位
2015-08-21 11:07
169 查看
在调试程序bug时经常会遇到需要定位代码的文件路径及行数的问题,比如在某些情况下,需要通过重载new和delete操作符,检测内存泄露,返回代码的位置
有几个编译器内置的宏定义,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用可以巧妙地帮我们输出非常有用的调试信息。
ANSI C标准中有几个标准预定义宏(也是常用的):
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__FUNCTION__:在源文件中插入当前函数名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus__:当编写C++程序时该标识符被定义。
编译器在进行源码编译的时候,会自动将这些宏替换为相应内容。
注意:上述下划线均为两个连写的下划线,一开始编译的时候老是出错,囧!
上测试代码:
运行结果:
8
current file:C:\Users\clpwk\Desktop\C++\代码定位.cpp
current line:10
current function:main
有几个编译器内置的宏定义,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用可以巧妙地帮我们输出非常有用的调试信息。
ANSI C标准中有几个标准预定义宏(也是常用的):
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__FUNCTION__:在源文件中插入当前函数名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus__:当编写C++程序时该标识符被定义。
编译器在进行源码编译的时候,会自动将这些宏替换为相应内容。
注意:上述下划线均为两个连写的下划线,一开始编译的时候老是出错,囧!
上测试代码:
#include<iostream> //#include<cstdio> using namespace std; int main() { cout<<sizeof(size_t)<<endl;//最大整数的长度 cout<<"current file:"<<__FILE__<<endl; cout<<"current line:"<<__LINE__<<endl; cout<<"current function:"<<__FUNCTION__<<endl; return 0; }
运行结果:
8
current file:C:\Users\clpwk\Desktop\C++\代码定位.cpp
current line:10
current function:main
相关文章推荐
- Python笔记
- Java实现归并排序和快速排序
- ipython 报错:pkg_resources.DistributionNotFound: importlib
- java一些重要工具类
- phpstorm+Xdebug断点调试PHP
- windows环境下的opencv在qt(msvc)上使用的配置
- c++ 重载== 相关
- 如何让spring mvc web应用启动时就执行特定处理
- SpringMVC学习系列(6) 之 数据验证
- [C++]Valid Palindrome 有效回文
- C# 中的INotifyPropertyChanged和ObservableCollection<T>
- C++/winapi截屏保存BMP
- ::和.的区别
- 终于完成了Josephus的C语言实现啦~~
- Eclipse 下利用 gradle 构建系统
- eclipse代码检查工具-FindBugs介绍
- 【Python】变量数值交换、判断数组是否含有某个元素
- 关于C#的delegate(委托)和event(事件)的使用
- PHP函数补完 - var_export
- C#截取字符串长度 返回string