Debug和Release分状态调试
复制代码
1
2
3
4
5
#if !DEBUG
Console.WriteLine("Release:TML发布的时候最帅了");
#else
Console.WriteLine("DEBUG:TML调试的时候最帅了");
#endif
如果运行模式是Release,也就是!DEBUG则会输出“Release:TML发布的时候最帅了”。如果运行模式是Debug,则代码会输出“DEBUG:TML调试的时候最帅了”。 Debug和Release的设置和基本原理我在《深入理解CLR》中详细论述过:
传送门 https://blog.csdn.net/sinat_33087001/article/details/80185199
那么什么时候用这种方式调试呢?
当出现这种情况,代码在线程里,这个时候打断点跳进去的时候不利于观察,这个时候可以设置在DEBUG状态下不执行线程,只执行线程内部代码,方便调试,在发布的时候(Release)加上线程部分的内容,不影响发版上线。
通过日志查看异常信息
复制代码
1
2
3
4
5
6
7
8
9
10
11
try{
foreach(var item1 in listA){
foreach(var item2 in listA){
item1==item2;
}
}
}
catch (Exception ex)
{
logger.Error("元数据异步校验失败", ex);
}
上例中双层循环里报错了,可能两个list有5000多次加起来,一遍一遍的断点调试并没有效果,所以,这个时候打印日志和堆栈信息就很有必要了。
最后
以上就是爱撒娇手套最近收集整理的关于【C#编程最佳实践 十四】VS调试最佳实践的全部内容,更多相关【C#编程最佳实践内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复