时间:2021-05-20
dynamic是FrameWork4.0的新特性。dynamic的出现让C#具有了弱语言类型的特性。编译器在编译的时候不再对类型进行检查,编译期默认dynamic对象支持你想要的任何特性。比如,即使你对GetDynamicObject方法返回的对象一无所知,你也可以像如下那样进行代码的调用,编译器不会报错:
dynamic dynamicObject = GetDynamicObject();Console.WriteLine(dynamicObject.Name);Console.WriteLine(dynamicObject.SampleMethod());说到正确用法,那么首先应该指出一个错误用法:
常有人会拿var这个关键字来和dynamic做比较。实际上,var和dynamic完全是两个概念,根本不应该放在一起做比较。var实际上是编译期抛给我们的“语法糖”,一旦被编译,编译期会自动匹配var 变量的实际类型,并用实际类型来替换该变量的申明,这看上去就好像我们在编码的时候是用实际类型进行申明的。而dynamic被编译后,实际是一个object类型,只不过编译器会对dynamic类型进行特殊处理,让它在编译期间不进行任何的类型检查,而是将类型检查放到了运行期。
这从visual studio的编辑器窗口就能看出来。以var声明的变量,支持“智能感知”,因为visual studion能推断出var类型的实际类型,而以dynamic声明的变量却不支持“智能感知”,因为编译器对其运行期的类型一无所知。对dynamic变量使用“智能感知”,会提示“此操作将在运行时解析”。
关于dynamic变量是一个object变量这一点,可以通过IL代码得到验证,这里不再贴出IL代码。当然,编译器也对dynamic声明进行了处理,以区别直接object变量。
dynamic是做为简化互操作性而被MSDN中大肆渲染,我感觉正是基于这一点,才被部分开发人员误解:因为很多开发人员不会接触COM+、OFFICE二次开发之类的编码,所以急需要一个dynamic的应用理由。那么,在日常开发中,我认为dynamic很有价值的一点是:
类型转换
Dynamic类型的实例和其他类型的实例间的转换是很简单的,开发人员能够很方便地在dyanmic和非dynamic行为间切换。任何实例都能隐式转换为dynamic类型实例,见下面的例子:
dynamic d1 = 7;dynamic d2 = "a string";dynamic d3 = System.DateTime.Today;dynamic d4 = System.Diagnostics.Process.GetProcesses();Conversely, an implicit conversion can be dynamically applied to any expression of type dynamic.反之亦然,类型为dynamic的任何表达式也能够隐式转换为其他类型。
int i = d1;string str = d2;DateTime dt = d3;System.Diagnostics.Process[] procs = d4;方法中含有dynamic类型参数的重载问题
如果调用一个方法是传递了dynamic类型的对象,或者被调用的对象是dynamic类型的,那么重载的判断是发生在运行时而不是编译时。
动态语言运行时(dynamic language runtime DLR)
动态语言运行时是.NET Framework 4 Beta 1中的一组新的API,它提供了对c#中dynamic类型的支持,也实现了像IronPython和IronRuby之类的动态程序设计语言。
dynamic可以简化反射。
以前我们这样使用反射:
public class DynamicSample{public string Name { get; set; }public int Add(int a, int b){return a + b;}}DynamicSample dynamicSample = new DynamicSample(); //create instance为了简化演示,我没有使用反射var addMethod = typeof(DynamicSample).GetMethod("Add");int re = (int)addMethod.Invoke(dynamicSample, new object[] { 1, 2 });现在,我们有了简化的写法:
dynamic dynamicSample2 = new DynamicSample();int re2 = dynamicSample2.Add(1, 2);我们可能会对这样的简化不以为然,毕竟看起来代码并没有减少多少,但是,如果考虑到效率兼优美两个特性,那么dynamic的优势就显现出来了。编译器对dynamic进行了优化,比没有经过缓存的反射效率快了很多。如果非要比较,可以将上面两者的代码(调用Add方法部分)运行1000000就可以得出结论。
COM互操作性
C# 4.0包含了多个特性,改进了与传统COM API接口如Office自动化等的互操作性。Dynamic类型、命名参数以及可选参数也属于改进中的一部分。
许多的COM方法允许其参数和返回值类型为object,因此对于强类型语言如C#来说,就需要做大量的强制类型转换。然而在C# 4.0中,如果在编译时加上/link选项,则dynamic类型就会起新的效果:它使得COM接口方法签名中的object类型(参数类型或返回类型)被视为dynamic,因而能够避免大量的类型转换工作。例如,下面的语句对此进行了对比。
// 没有用 dynamic.((Excel.Range)excel.Cells[1, 1]).Value2 = "Name";Excel.Range range = (Excel.Range)excel.Cells[1, 1];// 用了dynamic, excel.Cells[1, 1].Value = "Name";Excel.Range range = excel.Cells[1, 1];以上所述是小编给大家介绍的C#中dynamic关键字的正确用法(推荐),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例分析了C#中var关键字用法。分享给大家供大家参考。具体方法如下:C#关键字是伴随着.NET3.5以后,伴随着匿名函数、LINQ而来,由编译器帮我们推断
this关键字在C#程序设计中的应用非常频繁,今天本文就this关键字的用法做一番分析,希望能提对大家的C#程序设计有一定的帮助作用。具体分析如下:1.代表当前
C#4.0提供了一个dynamic关键字,那么什么是dynamic,究竟dynamic是如何工作的呢?从最简单的示例开始:复制代码代码如下:staticvoid
dynamic关键字和动态语言运行时(DLR)是.Net4.0中新增的功能。什么是"动态"? 编程语言有时可以划分为静态类型化语言和动态类型化语言。C#和Ja
接上文:C#Dynamic关键字之:ExpandoObject,DynamicObject,DynamicMetaOb的应用(上)为什么TryXXX方法没有被调