TextWriterTraceListener 和设计时属性支持文件xmta

TextWriterTraceListener 可行进行简单的日志记录

下面的示例实现 TextWriterTraceListener 类的一个实例,该类使用名为 myOutputWriter 的 StreamWriter 写入一个名为 TestFile.txt 的文件。 首先,此示例创建用于输出的文件。 然后,它为第一个文本编写器创建 StreamWriter,将输出文件分配给它,并将其添加到 Listeners。 然后,该代码将一行文本输出到该文件。 最后,该示例刷新输出缓冲区。

在运行此示例后,可以打开 TestFile.txt 文件查看输出。

public class Sample
{

public static int Main(string[] args) {
    // Create a file for output named TestFile.txt.
    Stream myFile = File.Create("TestFile.txt");

    /* Create a new text writer using the output stream, and add it to
     * the trace listeners. */
    TextWriterTraceListener myTextListener = new
       TextWriterTraceListener(myFile);
    Trace.Listeners.Add(myTextListener);

    // Write output to the file.
    Trace.Write("Test output ");


    // Flush the output.
    Trace.Flush();

    return 0;
 }

}

 

另外我们可以通过配置App.config来生成日志文件

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <system.diagnostics>
    <trace autoflush="false" indentsize="4">
      <listeners>
        <add name="myListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="aa.log"></add>
        <remove name="Default"></remove>
      </listeners>
    </trace>
  </system.diagnostics>
</configuration>

然后直接在代码中用Trace.write("aaaaa");Trace.flush();就能写入相关文件

因为是直接配置在App.config中,所以部署的时候一定要记得带上.exe.config文件,应用程序是运行的时候会读取这个配置文件.

或者你把App.config属性设置其为嵌入的资源,那样子就会嵌入到exe文件中去了. 

 

DesignTimeAttributes1.xmta文件(有时候我们在设置控件时调用了dllimport引入外部dll文件后,我们的自定控件就不能正常显示,加上这个文件,就能解决问题):

<?xml version="1.0" encoding="utf-16"?>
<Classes xmlns="http://schemas.microsoft.com/VisualStudio/2004/03/SmartDevices/XMTA.xsd">
  <Class Name="DeliveryInHand.ModelForm">
    <DesktopCompatible>true</DesktopCompatible>
  </Class>
</Classes>

 

posted @ 2012-07-19 16:54  广拓小程序  阅读(1422)  评论(0编辑  收藏  举报