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

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

1. 自定义EventSource,如下:

public class StoreEventSource : EventSource
{
public static StoreEventSource Instance = new StoreEventSource(); [Event(, Level = EventLevel.Verbose)]
public void Debug(string message)
{
this.WriteEvent(, message);
} [Event(, Level = EventLevel.Informational)]
public void Info(string message)
{
this.WriteEvent(, message);
} [Event(, Level = EventLevel.Warning)]
public void Warn(string message)
{
this.WriteEvent(, message);
} [Event(, Level = EventLevel.Error)]
public void Error(string message)
{
this.WriteEvent(, message);
} [Event(, Level = EventLevel.Critical)]
public void Critical(string message)
{
this.WriteEvent(, message);
}
}

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

2. 自定义EventListenter

    sealed class IsolatedStorageEventListener : EventListener
{
private StorageFile store; public IsolatedStorageEventListener(string location)
{
init(location);
} async void init(string location)
{
store = await ApplicationData.Current.LocalFolder.CreateFileAsync(location, CreationCollisionOption.ReplaceExisting);
} protected async override void OnEventWritten(EventWrittenEventArgs eventData)
{
StringBuilder builder = new StringBuilder();
builder.AppendLine(eventData.EventId.ToString());
foreach (object o in eventData.Payload)
{
builder.AppendLine(o.ToString());
}
await FileIO.AppendTextAsync(store, builder.ToString());
} public override void Dispose()
{
base.Dispose();
}
}

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

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

3.调用

IsolatedStorageEventListener listener;

        private void btnDebug_Click_1(object sender, RoutedEventArgs e)
{
if (listener == null)
{
listener = new IsolatedStorageEventListener("test.txt");
listener.EnableEvents(StoreEventSource.Instance, EventLevel.LogAlways);
} StoreEventSource.Instance.Debug("TestTest");
}

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. [学习笔记]Spring依赖注入

    依赖: 典型的企业应用程序不可能由单个对象(在spring中,也可称之bean)组成,再简单的应用也是由几个对象相互配合工作的,这一章主要介绍bean的定义以及bean之间的相互协作. 依赖注入: s ...

  2. ruby,python及curl post请求

    #飘红部分为变量 test_url="http://test" body_hash={"value"=>100, "year"=> ...

  3. Wamp错误: Forbidden You don't have permission to access / on this server.

    找到php的配置文件httpd.conf(找不到的话看这篇:http://www.cnblogs.com/liulangmao/p/3569807.html) 在原有的位置文件中找到配置节 <D ...

  4. 【快速查阅】Linux下启动和关闭Weblogic(管理服务器+被管服务器)

    Weblogic的管理服务器和被管服务器的启动.关闭,偶尔会用到,却又不常用,导致需用时却忘记了,而又重新查阅HELP. 故,以此记录,方便查阅.执行. 首先,weblogic的启动脚本和关闭脚本都在 ...

  5. C/C++/C#/Python日志框架

    俗话说,打得一手好log才是一个优秀的程序员. **打log的目的是为了迅速排错或在有争议时拿出证据证明自己.基于这个目的,log不在多,只要抓住一切对自己有利的信息,就可以了.** 日志框架列表 C ...

  6. Oracle PL/SQL 编程基础 实例

    create table mytest(name varchar(20),password varchar(30)); create or replace procedure sp_pro2 is  ...

  7. 【Unity】同时打开多个项目工程

    需求:学习Unity时经常会边参考别人的工程边写自己的Demo工程,需要同时打开多个项目工程. 网上查询的方式大约有两种: 在Edit->Preferences->Editor Analy ...

  8. QT4.8.5 QComboBox 增加选择菜单记录

    QT4.8.5 QComboBox 增加选择菜单记录 因为软件需要测试多个UART ,多个LAN,当要测试多个同样功能的时候就可以使用QComboBox类实现一个菜单选择功能. 步骤如下: 1. 在U ...

  9. java——关于异常处理机制的简单原理和应用

    异常处理机制的简单原理和应用 一.Execption可以分为java标准定义的异常和程序员自定义异常2种 (1)一种是当程序违反了java语规则的时候,JAVA虚拟机就会将发生的错误表示为一个异常.这 ...

  10. hive输出json字符串

    目前没发现有什么方便的函数可以直接使用,只能使用concat来手工拼接. 注意将null的字段值转为空,使用nvl函数 如果将hql语句写在script.q文件里面如下: select concat( ...