C# 用Trace.WriteLine输出调试信息无法查看

本文讲述了在C#编程中遇到控制台输出混乱的问题,介绍了使用Trace.WriteLine()和Debug.WriteLine()方法进行调试,以及如何借助DebugView工具通过设置关键字过滤输出,以提高调试效率。
摘要由CSDN通过智能技术生成

    写程序就会遇见BUG,这时候在代码不同部位输出一些标记的信息对查找错误非常有必要,一般情况下我们都是使用Console.WriteLine()方法来打印信息到控制台窗口,但有时候使用Console.WriteLine()方法会存在不方便的情况,比如鄙人遇到的问题就是程序因为用了一些其他的库,这些第三方库也会打印一些信息到控制台窗口里,造成程序运行时控制台窗口里的信息一大堆一大堆的非常混乱,根本看不到鄙人自己想显示的信息,非常令人头疼。

    然后鄙人就琢磨用C#自己提供的输出调试信息的方法来显示鄙人自己想显示的信息,C#提供了如下几个方法来输出调试信息,例如创建一个WinForm窗口程序,创建一个按钮,在按钮的回调函数里使用Trace.WriteLine()方法:

    当然也可以用Debug.WriteLine()方法,C#提供了如下几个方法来输出调试信息:

需要先引入命名空间:

using  System.Diagnostics;

调用方式:

Debug.WriteLine();

Debug.WriteLineIf();//两个参数,当第一个参数为true时,第二个参数的调试信息会显示出来。

Trace.WriteLine();//Release版本,当然Debug中也可以显示

Trace.WriteLineIf();//同上

    但是在Release状态下点了好几次输出框什么信息也没有,翻了一些资料改了Visual Studio的一些设置也无济于事,后来鄙人忽然想起之前开发驱动时用到的DebugView这个工具,驱动要输出调试信息是没办法直接看到的,所以就需要有个工具来查看驱动运行时设置的调试信息。这个工具也可以接收一般的exe程序输出的调试信息。

    这个工具最友好的地方是可以设置关键字来过滤输出信息,这样只要我们给自己的输出信息插入一个统一的字符串然后再以这个字符串为过滤条件就能很轻易的看到我们想要输出的调试信息了。

    

文中提到的工具:

DebugView

提取码: 9m4r

假如你的杀毒软件显示汉化版有毒那请自行考虑,反正鄙人用安全管家扫描是不报毒,实在不放心可以用英文原本,或者自行去微软下载。

微软提供的DebugView v4.90

注意:DebugView需要右键→管理员身份运行才能捕获调试信息,直接运行权限是不够的。

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在WPF程序中,使用Console.WriteLine()函数无法直接输出调试信息。这是因为WPF应用程序并不直接使用控制台窗口进行输出。相反,可以使用System.Diagnostics.Trace.WriteLine()或System.Diagnostics.Debug.WriteLine()函数来输出调试信息。这两个函数都是用于在调试过程中输出消息和跟踪信息的。可以在代码中添加这些函数来输出所需的调试信息。请注意,在发布应用程序时,这些调试信息应该被移除或禁用,以避免对性能产生负面影响。 在引用中的代码中,Console.WriteLine()函数也无法输出日志信息。与WPF应用程序类似,这是因为该应用程序是Windows Presentation Foundation (WPF)项目。然而,当作者将项目模板更改为WPF模板后,就可以使用Console.WriteLine()函数打印日志消息了。这可能是由于在更改模板后,控制台输出被重新启用,因此Console.WriteLine()函数可以正常运行。 综上所述,如果您在WPF或WPF项目中想要输出调试或日志信息,应该使用System.Diagnostics.Trace.WriteLine()或System.Diagnostics.Debug.WriteLine()函数。如果您想使用Console.WriteLine()函数,需要确保项目模板或设置允许控制台输出。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [.Net5下Console.WriteLine()方法无输出](https://blog.csdn.net/qq_41415661/article/details/117664624)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [C# WPF框架下 Console.WriteLine()无法打印内容](https://blog.csdn.net/u012190031/article/details/119186058)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值