如何在Windows Service或者Windows Forms输出Console.Write的信息

我们很多人都喜欢在一些代码中使用Console.Write或者Console.WriteLine的方式输出一些信息,这种做法,如果用到控制台程序中,是很方便的。但是如果用到了Windows Service或者Windows Forms程序中,那么就不是那么好了,因为它们并没有所谓的Console。(如果我们是在Visual Studio中进行调试的话,会输出到一个Output窗口)

先来看Windows Service的做法。我们可以将这个输出流重定向到一个文件。

            StreamWriter sw = new StreamWriter("e:\\temp\\log.log");
            sw.AutoFlush = true;
            Console.SetOut(sw);
 
image 
而在Windows Forms中呢,当然也可以像上面这样做,但是我们可能希望现在在窗体的一个文本框中,看下面的例子
首先可以编写一个特殊的TextWriter
        public class TextBoxWriter : TextWriter
        {
            TextBoxBase _textbox;
            public TextBoxWriter(TextBoxBase textbox) {
                _textbox = textbox;
            }

            public override Encoding Encoding
            {
                get { return Encoding.UTF8; }
            }

            public override void WriteLine(string value)
            {
                base.WriteLine(value);
                _textbox.AppendText(value + Environment.NewLine);
            }
        }

然后使用该TextWriter来输出消息到窗体的一个文本框中

            TextBoxWriter tw = new TextBoxWriter(richTextBox1);
            Console.SetOut(tw);

image

 

当然,如果仅仅是为了做一些跟踪性的输出,则更推荐使用Trace,结合TraceListener来实现。因为Trace是可以有多个输出的,事实上,确实也有一个ConsoleTraceListener可以输出到屏幕上。

 

 

 

 
 
posted @   陈希章  阅读(2471)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
历史上的今天:
2009-04-21 sp_MSforeachtable和sp_MSforeachdb
2009-04-21 ToString 的几个思考
2009-04-21 安全和公共只读数组字段
2009-04-21 Microsoft Sync Framework
点击右上角即可分享
微信分享提示