做日志组件时,常常会记录调用者信息,通常都是通过反射来获取相应信息。不过.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 }