c#方法参数的自定义属性 – 它是如何工作的?

前端之家收集整理的这篇文章主要介绍了c#方法参数的自定义属性 – 它是如何工作的?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想了解这个特殊情况的工作原理.以下是msdn文章中的内容,其中解释了INotifyPropertyChanged接口( https://msdn.microsoft.com/query/dev12.query?appId=Dev12IDEF1&l=EN-US&k=k%28System.ComponentModel.INotifyPropertyChanged%29;k%28TargetFrameworkMoniker-.NETFramework,Version%3Dv4.5%29;k%28DevLang-csharp%29&rd=true)

正如在标记行中所说,有一种方法可以拦截方法调用来替换值而不是实际的值作为参数?
我想知道这样做的代码是什么样的.我知道如何使用为属性和其他类成员设置的属性,但这个用例对我来说并不清楚.

谢谢.

解决方法

它似乎是编译器中实现的一个特性:它知道这个特殊属性,并且当它具有默认值时,它将调用者的名称替换为可选参数.

如果您愿意,可以查看Roslyn实现.尽管导航并不总是非常简单,但GetDefaultParameterValue函数中似乎有一些here(从第844行开始,至少在截至编写本时的当前版本中为0db946b):

if the optional parameter is annotated with <see cref="CallerLineNumberAttribute"/>,<see cref="CallerFilePathAttribute"/> or <see cref="CallerMemberNameAttribute"/>,and there is no explicit argument corresponding to it,we will provide caller information as a value of this parameter.

在第912行,有一个else if子句处理这种情况(if之前的if和else if子句处理类似的新功能CallerLineNumberAttribute和CallerFilePathAttribute):

...
else if (parameter.IsCallerMemberName && ((callerSourceLocation = GetCallerLocation(Syntax,enableCallerInfo)) != null))
...

最终用于绑定参数:

BoundExpression memberNameLiteral = MakeLiteral(Syntax,ConstantValue.Create(memberName),_compilation.GetSpecialType(SpecialType.System_String));
defaultValue = MakeConversion(memberNameLiteral,parameterType,false);

猜你在找的C#相关文章