[英]Adding references in NETStandard class library
我正试图绕过NETStandard类库,找到我正在研究的潜在NuGet包。 这是我第一次使用NuGet和NETStandard软件包,所以我在某些方面有点迷失,其中一个是引用系统库。
dynamic
类型是System.Runtime.CompilerServices.DynamicAttribute
一部分,但是,不存在对所述DLL的引用。 我虽然我会继续添加它,但我似乎无法这样做。 我想这不像框架类库那样工作?
如果我在解决方案资源管理器中右键单击我的Dependencies
文件夹,然后单击Add Reference...
,我似乎无法找到可以使用的任何依赖项。 不在Assemblies
选项卡下, Assemblies
- > Framework
或Extensions
下没有任何内容。
我只是想了解这实际上是如何工作的,为什么我找不到任何依赖?
右键单击项目的“依赖项”节点>“管理Nuget包”>“浏览”,然后在搜索框中键入“dynamic”。 从列表顶部选择System.Dynamic.Runtime
,现在您可以在源代码中使用dynamic
。
如果您对我感兴趣的原因是为什么您可以使用dynamic
关键字而不在方法的代码中引用DLR库,但不能在属性的声明中继续阅读。
看看下面的C#代码行,它们在没有引用System.Dynamic.Runtime
情况下使用NETStandard.Library进行编译时没有任何问题。 下面C#代码中第1行和第3行之间的主要区别是关键字dynamic vs var或dynamic vs static typing的用法。
Line 1: dynamic a = new {a = 1, b = 2};
Line 2: a = new Class1();
Line 3: var b = new { a = 1, b = 2 };
以下是相同三行的简化IL供您参考。
Line 1: newobj instance void class '<>f__AnonymousType0`2'<int32,int32>::.ctor(!0,!1)
Line 2: newobj instance void ClassLibrary2.Class1::.ctor()
Line 3: newobj instance void class '<>f__AnonymousType0`2'<int32,int32>::.ctor(!0,!1)
如果比较生成的IL代码的第1行和第3行,您将发现没有任何区别。 编译器可以从初始化代码推断变量的类型,并为不同类型启用相同变量的重新初始化。 此方案中不需要依赖DLR。
另一方面,当您将类的auto属性声明为dynamic
时,会发生完全不同的事情。
public class Class1 { public dynamic Test { get; set; } }
自动属性的IL代码揭示了dynamic
属性被转换为类型object
的私有后备字段以及初始化,getter和setter的代码,它严重依赖于System.Runtime.CompilerServices.DynamicAttribute
来自System.Dynamic.Runtime
在这种情况下引入了对DLR的依赖。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.