我创建了一个小型 C# winforms 应用程序,作为一项附加功能,我正在考虑向其中添加某种形式的错误日志记录。有人对解决这个问题有什么好的建议吗?这是我从未考虑过添加到以前的项目中的功能,因此我愿意接受有更多经验的开发人员的建议。
我正在考虑将异常写入指定的文本文件或可能的数据库表。该应用程序将使用几个月,然后在较大的产品完成后被丢弃。
我不会对外部库进行太多挖掘,因为您的日志记录需求很简单。
.NET Framework 已经在命名空间 System.Diagnostics 中附带了此功能,您可以通过简单地调用下面的方法来编写所需的所有日志记录:Trace http://msdn.microsoft.com/en-us/library/system.diagnostics.trace%28v=vs.110%29.aspx class:
Trace.TraceInformation("Your Information");
Trace.TraceError("Your Error");
Trace.TraceWarning("Your Warning");
然后在 app.config 文件中配置满足您需求的所有跟踪侦听器:
<configuration>
// other config
<system.diagnostics>
<trace autoflush="true" indentsize="4">
<listeners>
<add name="consoleListener" type="System.Diagnostics.ConsoleTraceListener"/>
<add name="textWriterListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="YourLogFile.txt"/>
<add name="eventLogListener" type="System.Diagnostics.EventLogTraceListener" initializeData="YourEventLogSource" />
<remove name="Default"/>
</listeners>
</trace>
</system.diagnostics>
// other config
</configuration>
或者,如果您愿意,您还可以在应用程序中配置侦听器,而不依赖于配置文件:
Trace.Listeners.Add(new TextWriterTraceListener("MyTextFile.log"));
请记住将 Trace.AutoFlush 属性设置为 true,以便文本日志正常工作。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)