Win8 Store App的日志输出不像Desktop App 那么简单,见 这篇文档(http://www.cnblogs.com/xiaokang088/archive/2011/12/27/2303725.html

经过同事指点加google,找到了办法。

1. 自定义EventSource,如下:

  1. public class StoreEventSource : EventSource
  2. {
  3. public static StoreEventSource Instance = new StoreEventSource();
  4.  
  5. [Event(, Level = EventLevel.Verbose)]
  6. public void Debug(string message)
  7. {
  8. this.WriteEvent(, message);
  9. }
  10.  
  11. [Event(, Level = EventLevel.Informational)]
  12. public void Info(string message)
  13. {
  14. this.WriteEvent(, message);
  15. }
  16.  
  17. [Event(, Level = EventLevel.Warning)]
  18. public void Warn(string message)
  19. {
  20. this.WriteEvent(, message);
  21. }
  22.  
  23. [Event(, Level = EventLevel.Error)]
  24. public void Error(string message)
  25. {
  26. this.WriteEvent(, message);
  27. }
  28.  
  29. [Event(, Level = EventLevel.Critical)]
  30. public void Critical(string message)
  31. {
  32. this.WriteEvent(, message);
  33. }
  34. }

关于这个EventSource,看似简单,说来话长,后面有篇文章,自行捉摸。

2. 自定义EventListenter

  1. sealed class IsolatedStorageEventListener : EventListener
  2. {
  3. private StorageFile store;
  4.  
  5. public IsolatedStorageEventListener(string location)
  6. {
  7. init(location);
  8. }
  9.  
  10. async void init(string location)
  11. {
  12. store = await ApplicationData.Current.LocalFolder.CreateFileAsync(location, CreationCollisionOption.ReplaceExisting);
  13. }
  14.  
  15. protected async override void OnEventWritten(EventWrittenEventArgs eventData)
  16. {
  17. StringBuilder builder = new StringBuilder();
  18. builder.AppendLine(eventData.EventId.ToString());
  19. foreach (object o in eventData.Payload)
  20. {
  21. builder.AppendLine(o.ToString());
  22. }
  23. await FileIO.AppendTextAsync(store, builder.ToString());
  24. }
  25.  
  26. public override void Dispose()
  27. {
  28. base.Dispose();
  29. }
  30. }

带没看起来都不复杂,蛮简单的,急用的同学可以直接拷贝。

注意:这里有问题:初始化文件的时候,用的是 await , 也就是说,在写日志的时候,有可能这里还没初始化完成,这个问题还没妥善解决。

3.调用

  1. IsolatedStorageEventListener listener;
  2.  
  3. private void btnDebug_Click_1(object sender, RoutedEventArgs e)
  4. {
  5. if (listener == null)
  6. {
  7. listener = new IsolatedStorageEventListener("test.txt");
  8. listener.EnableEvents(StoreEventSource.Instance, EventLevel.LogAlways);
  9. }
  10.  
  11. StoreEventSource.Instance.Debug("TestTest");
  12. }

log会写在这里:C:\Users\[username]\AppData\Local\Packages\[package name]\LocalState

[package name] 在  Package.appxmanifest\Packaging\Package name

好了,火急火燎的同学,您可以直接粘贴过去用了,貌似还 有点问题,我也在捉摸。

相关资料如下:

1. 这个EventSource 其实是用来做性能分析的,具体见下文。

Tracing with EventSource in .NET 4.5(http://dev.goshoom.net/en/2013/04/tracing-with-eventsource/)

2.关于ETW和PerView的博客,非常详细

Vance Morrison's Weblog(http://blogs.msdn.com/b/vancem/)

3.specification for EventSource , 这个很重要。

The specification for the System.Diagnostics.Tracing.EventSource class.
http://blogs.msdn.com/b/vancem/archive/2012/07/09/more-details-on-eventsource-the-class-specification.aspx

就这些了,我也是刚开始学习,不对的地方请多多指教。

win8 学习笔记二 输出日志的更多相关文章

  1. asp.net MVC日志插件Log4Net学习笔记二:保存日志到sqlserver的配置

    1.写到sqlserver的配置: <!--保存到SQLSERVER数据库日志--> <log4net> <appender name="AdoNetAppen ...

  2. python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码

    python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码 python的json.dumps方法默认会输出成这种格式"\u535a\u ...

  3. python3.4学习笔记(二) 类型判断,异常处理,终止程序

    python3.4学习笔记(二) 类型判断,异常处理,终止程序,实例代码: #idle中按F5可以运行代码 #引入外部模块 import xxx #random模块,randint(开始数,结束数) ...

  4. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  5. [Firefly引擎][学习笔记二][已完结]卡牌游戏开发模型的设计

    源地址:http://bbs.9miao.com/thread-44603-1-1.html 在此补充一下Socket的验证机制:socket登陆验证.会采用session会话超时的机制做心跳接口验证 ...

  6. JMX学习笔记(二)-Notification

    Notification通知,也可理解为消息,有通知,必然有发送通知的广播,JMX这里采用了一种订阅的方式,类似于观察者模式,注册一个观察者到广播里,当有通知时,广播通过调用观察者,逐一通知. 这里写 ...

  7. Java IO学习笔记二

    Java IO学习笔记二 流的概念 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入输 ...

  8. Django学习笔记二

    Django学习笔记二 模型类,字段,选项,查询,关联,聚合函数,管理器, 一 字段属性和选项 1.1 模型类属性命名限制 1)不能是python的保留关键字. 2)不允许使用连续的下划线,这是由dj ...

  9. Typescript 学习笔记二:数据类型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

随机推荐

  1. 完美解决 IOS系统safari5.0 浏览器页面布局iframe滚动栏失效问题

    在iframe外层包一层div,加入例如以下样式: style="-webkit-overflow-scrolling:touch;overflow:auto;" 代码例如以下: ...

  2. Linux下C语言使用openssl库进行加密

    在这里插一小节加密的吧,使用openssl库进行加密. 使用MD5加密 我们以一个字符串为例,新建一个文件filename.txt,在文件内写入hello ,然后在Linux下可以使用命令md5sum ...

  3. python匹配两个字符串中间的字符串

    问题:使用python正则如何匹配两字符串中间的字符串解决:使用re模块的findall,注意,re.match是只能从开头匹配的方法: import re html_str = '</a> ...

  4. 【Java】Collection与Map接口总结

    Collection     -----List                -----LinkedList    非同步                 ----ArrayList      非同 ...

  5. Redis Keys 命令 - 查找所有符合给定模式( pattern)的 key

    Redis Keys 命令用于查找所有符合给定模式 pattern 的 key .. 语法 redis KEYS 命令基本语法如下: redis 127.0.0.1:6379> KEYS PAT ...

  6. JAVA-JSP注释

    相关资料: <21天学通Java Web开发> 结果总结: 1.一类可以在客户端显示的注释,即HTML注释.2.<!-- -->,中间为注释部分.3.如果使用MyEclipse ...

  7. 深入分析java中文乱码问题

    http://www.ibm.com/developerworks/cn/java/j-lo-chinesecoding/

  8. sendmsg/recvmsg和struct msghdr

    函数原型 #include <sys/types.h> #include <sys/socket.h> ssize_t sendmsg(int sockfd, const st ...

  9. iOS错误整理--自定义按钮,给按钮内部赋值出现的错误

    一.练习中为了实现自定义按钮,按钮中的imageView和titleLabel默认是左右排列的.在练习中自定义为上下排列. *在以下方法中重新布局按钮中的子控件 - (void)layoutSubvi ...

  10. golang 数组以及slice切片

    老虞学GoLang笔记-数组和切片   数组 Arrays 数组是内置(build-in)类型,是一组同类型数据的集合,它是值类型,通过从0开始的下标索引访问元素值.在初始化后长度是固定的,无法修改其 ...