很多时候,我们需要在运行过程中记录一些调测的日志信息,如下所示: public void DoProcessing() { TraceMessage("DoProcessing()被XXX调用");//这里需要知道当前谁调用了DoProcessing(),由于我们并不知道是谁调用了DoProcessing(),所以字符串中的XXX不得而知,无法将完整的日志信息用TraceMessage方法记入日志 } 上面TraceMessage("DoProcessing()被XXX调用&…
连载目录    [已更新最新开发文章,点击查看详细] 通过使用调用方信息特性,可获取有关方法的调用方的信息. 可以获取源代码的文件路径.源代码中的行号和调用方的成员名称. 此信息有助于跟踪.调试和创建诊断工具.若要获取此信息,可以使用应用于可选参数的特性,每个特性都具有默认值. 下表列出在 System.Runtime.CompilerServices 命名空间中定义的调用方信息特性: 特性 描述 类型 CallerFilePathAttribute 包含调用方的源文件的完整路径. 这是编译时的…
SAMPLE.DSM是微软提供的样例,使用的是vb语言.其中的 CommentOut 函数,是支持块注释的,可是这种/**/的注释方式,有时候用起来不是很方便,因为两个/会因为一个/而终止.对于大块代码,使用//注释,仅需修改原样例函数中的少部分代码. 取消注释的实现,可以在注释的基础上进行修改.两个函数的源码如下: Sub CommentOut () 'DESCRIPTION: Comments out a selected block of text. Dim win set win = A…
http://www.cnblogs.com/yxyht/archive/2013/03/02/2939883.html   ASP.NET中TextBox控件设置ReadOnly="true"H或Enabled=false后台取不到值 当TextBox设置了ReadOnly="true" 后,要是在前台为控件添加了值,后台是取不到的,值为“空”  .   方法一:不设置ReadOnly属性,通过onfocus=this.blur()来模拟,如下:   <as…
TC9.0的history.txt里有几行更新说明(见文章末尾),可以用SendMessage命令获取信息, 消息号是WM_USER+50(即1074),wParam则是更新说明里的内容, 下面是我简单整理后的结果(带*是实用功能): 1-29是获取控件id,分别是消息号.控件名称.说明 1/2 TMyListBox2/1 左/右侧列表 3/4* 参考上面 来源/对面文件列表 5/6 THeaderClick1/2 左/右标签 7/8 TMyPanel5/8 左/右状态栏 9/10* TPath…
C# 5.0随着VisualStudio 2012一起正式发布了,让我们来看看C#5.0中增加了哪些功能. 1. 异步编程 在.Net 4.5中,通过async和await两个关键字,引入了一种新的基于任务的异步编程模型(TAP).在这种方式下,可以通过类似同步方式编写异步代码,极大简化了异步编程模型.如下式一个简单的实例: static async void DownloadStringAsync2(Uri uri) { var webClient = new WebClient(); var…
var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i=arguments;t.queue.push(function(){t[config].apply(t,i)})}}var t={config:config},u=document,e=window,o="script",s=u.createElement(o),i,f;for(s.src…
在写记录日志功能时,需要记录日志调用方所在的模块名.命名空间名.类名以及方法名,想到使用的是反射(涉及到反射请注意性能),但具体是哪一块儿还不了解,于是搜索,整理如下: 需要添加相应的命名空间: using System; using System.Diagnostics; using System.Reflection; 如果仅是获取当前方法名使用 MethodBase.GetCurrentMethod 方法(返回表示当前正在执行的方法的 MethodBase 对象),可以使用如下代码: pu…
在开发中经常会写个公有静态类记录日志,如下: /// <summary> /// Writes the error. /// </summary> /// <param name="message">The message to be written.</param> public void WriteError(object message) { _log4Net.Error(message); } 如果想区分调用来源就比较麻烦了.在.…
介绍 标题中所说的三个特性 CallerMemberNameAttribute / CallerFilePathAttribute / CallerLineNumberAttribute 我们统称为调用者信息特性,正常情况下在 .NET Framework 4.0 中是无法使用的.因为这三个特性是 .NET Framework 4.5 中新增的.然而这三个特性的作用只是请求编译器在编译过程中进行代码的转换. 使用示例 static void Main( string[] args ) { var…