[新]可精确到1毫秒的用以在记录文件中写入自定义的调试信息(主要是时间)的组件

2016-01-29 12:59 10 1 收藏

[新]可精确到1毫秒的用以在记录文件中写入自定义的调试信息(主要是时间)的组件,[新]可精确到1毫秒的用以在记录文件中写入自定义的调试信息(主要是时间)的组件

【 tulaoshi.com - ASP.NET 】

上次我发布了一个用以在记录文件中写入自定义的调试信息(主要是时间)的组件,但由于CLR的限制,它只能精确到10毫秒左右。后来我参考了网络上的一篇文章:http://blog.joycode.com/lostinet/archive/2005/04/24/49590.aspx(在这里首先向原作者表示感谢)通过调用系统API得到了可精确到1毫秒左右的时间记录。故特重新用C#重写了这个组件,与大家共享。//====================================================================//TraceSpy - 用以在记录文件中写入自定义的调试信息(开发者:林健)//====================================================================////属性:// TraceFileName - 记录文件名////方法:// ★文本写入方面// WriteText - 写入自定义文本// ClearAllText - 清除所有文本// ★时间记录方面// SetTimePoint - 设置时间起点// GetTimeSpanFromInit - 询问时间跨度(距离时间起点)// GetTimeSpanFromPrev - 询问时间跨度(距离上次询问时间)// ★自定义计数器// SetCounter - 设置自定义计数器// AddCounter - 累加自定义计数器////====================================================================using System;namespace TraceSpy{ public class TheTrace { //记录文件名 static public string TraceFileName = "Trace.txt"; //时间起点(初始为当前时刻) static private long InitTimePoint = TimeCounter.GetExactNow().Ticks; //上次询问时间点(初始为当前时刻) static private long PrevTimePoint = TimeCounter.GetExactNow().Ticks; //自定义计数器 static private int counter = 0; //写入自定义文本 static public void WriteText(string str) { WriteText(str, false); } static public void WriteText(string str, bool showTime) { FileWriter.WriteText(str, showTime); } //清除所有文本 static public void ClearAllText() { FileWriter.ClearAllText(); } //设置时间起点 static public void SetTimePoint() { SetTimePoint(""); } static public void SetTimePoint(string note) { InitTimePoint = TimeCounter.GetExactNow().Ticks; PrevTimePoint = TimeCounter.GetExactNow().Ticks; FileWriter.WriteText("设置时间起点[" + note + "]。", false); } //询问时间跨度(距离时间起点) static public decimal GetTimeSpanFromInit() { return GetTimeSpanFromInit(""); } static public decimal GetTimeSpanFromInit(string note) { PrevTimePoint = TimeCounter.GetExactNow().Ticks; decimal span; span = (decimal)(PrevTimePoint - InitTimePoint) / (decimal)10000; FileWriter.WriteText("询问时间跨度[" + note + "],距离时间起点为" + span.ToString() + "毫秒。", false); return span; } //询问时间跨度(距离上次询问时间) static public decimal GetTimeSpanFromPrev() { return GetTimeSpanFromPrev(""); } static public decimal GetTimeSpanFromPrev(string note) { long RectTimePoint =TimeCounter.GetExactNow().Ticks; decimal span; span = (decimal)(RectTimePoint - PrevTimePoint) / (decimal)10000; PrevTimePoint = RectTimePoint; FileWriter.WriteText("询问时间跨度[" + note + "],距离上次询问时间为" + span.ToString() + "毫秒。", false); return span; } //设置自定义计数器 static public int SetCounter() { return SetCounter(0); } static public int SetCounter(int num) { counter = num; FileWriter.WriteText("自定义计数器值设置为" + counter + "。", false); return counter; } //累加自定义计数器 static public int AddCounter() { return AddCounter(1); } static public int AddCounter(int num) { counter += num; FileWriter.WriteText("自定义计数器值累加到" + counter + "。", false); return counter; } }}using System;using System.Runtime.InteropServices;namespace TraceSpy{ internal class TimeCounter { [DllImport("kernel32.dll")] static extern bool QueryPerformanceCounter([In, Out] ref long lpPerformanceCount); [DllImport("kernel32.dll")] static extern bool QueryPerformanceFrequency([In, Out] ref long lpFrequency); static long _f = 0; static private long GetTickCount() { long f = _f; if (f == 0) { if (QueryPerformanceFrequency(ref f)) { _f = f; } else { _f = -1; } } if (f == -1) { return Environment.TickCount * 10000; } long c = 0; QueryPerformanceCounter(ref c); return (long)(((double)c) * 1000 * 10000 / ((double)f)); } static long _tc = 0; static internal DateTime GetExactNow() { if (_tc == 0) { long tc = Ge

来源:http://www.tulaoshi.com/n/20160129/1488413.html

延伸阅读
标签: Web开发
一、基本概念: 1.标签(Tag): 标签是一种XML元素,通过标签可以使JSP网页变得简洁并且易于维护,还可以方便地实现同一个JSP文件支持多种语言版本。由于标签是XML元素,所以它的名称和属性都是大小写敏感的 2.标签库(Tag library): 由一系列功能相似、逻辑上互相联系的标签构成的集合称为标签库。 3.标签库描述文件(Tag Library Descriptor...
打造自定义的 AfxMessageBox 作者:1.5kg 下载源代码 一、需求 与标准的 MessageBox 相比,MFC提供了 AfxMessageBox 的方法是我们对消息框的变得更加容易。然而简单的 AfxMessageBox 有时已经不能够满足我们的需求了:有时候我仅仅想提示用户一下,并不需要用户确认,也就是说过一段时间消息框...
标签: Web开发
Lucene中的自定义排序功能和Java集合中的自定义排序的实现方法差不多,都要实现一下比较接口. 在Java中只要实现Comparable接口就可以了.但是在Lucene中要实现SortComparatorSource接口和ScoreDocComparator接口.在了解具体实现方法之前先来看看这两个接口的定义吧. SortComparatorSource接口的功能是返回一个用来排序ScoreDocs的comparator(Expe...
标签: Painter
paintewww.Tulaoshi.comr的pattern(图案)可以作出很多的特效,可以结合特殊的笔刷,还有特效命令。这里先了解一下自定义图案,其他功能以后讲 1.CTRL+N新建一个合适大小的空白文件。CTRL+F打开Fill(填充)的对话框,选择Current color(当前颜色),并在色板上选择自己喜欢的颜色。 2.选择Calligraphy/Dry ink(书法笔/干墨...
有人提问说AutoCAD中如何自定义线型,自己操作了许久都不太顺,后来想到即然CAD有自带线型,一定可以利用它原来的文件编改一下定义成新的线型。现在就和大家一起分享。 如下图,找到以下路径 图1 再找到acadiaso.lin这个文件,双击打开。 图2 打开文件后,找到和你录求最相近的线型,我以求助问题贴为例,他是要"热管---热管--...

经验教程

857

收藏

79
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部