C# 调用者信息获取

     做日志组件时,常常会记录调用者信息,通常都是通过反射来获取相应信息。不过.Net 4.5引入了三个新的特性,即CallerFilePathAttribute,CallerLineNumberAttribute和CallerMemberNameAttribute。这三个特性都只能应用于参数并且只有在应用与可选参数时才有用。其理念非常简单:如果调用点没有提供实参,则编译器可使用当前文件,行数或成员名来作为实参,而不是使用常规的默认值,如果调用者提供了实参,编译器则将忽略这些特性。

 1 class ProgramCallerLineNumberAttribute
 2     {
 3         static void Main(string[] args)
 4         {
 5             Log.LogWrite("test");
 6             Console.ReadKey();
 7         }
 8     }
 9 
10     class Log
11     {
12         public  static void LogWrite(string logInfo,
13             [CallerFilePath] string file=null,
14             [CallerLineNumber] int  line=0,
15             [CallerMemberName] string member=null
16             )
17         {
18             Console.WriteLine(logInfo);
19             Console.WriteLine(file);
20             Console.WriteLine(line);
21             Console.WriteLine(member);
22 
23         }
24     }

 

posted @ 2017-10-22 17:18  who?  阅读(1963)  评论(0编辑  收藏  举报