.NET4.0 之 Dynamic VS Refle“.NET研究”ction 效率

简介:   在我先前的文章中,不断的推广.NET4.0新特性。特别是.NET4.0 Dynamic 这个新特性。随之而来的问题也出现了—Dynamic 执行效率如何?  我们做开发的不光需要代码简洁,能够希望自己能够写出好的架构。

  在我先前的文章中,不断的推广.NET4.0新特性。特别是.NET4.0 Dynamic 这个新特性。随之而来的问题也出现了—Dynamic 执行效率如何?

  我们做开发的不光需要代码简洁,能够希望自己能够写出好的架构。还有一点非常重要的就是,我们的写出来的代码效率。撇开Dynamic在.net4.0中的实现原理。本篇只考虑dynamic 的效率比起使用反射到底是快还是慢?难道.NET为引入了dynamic这个新鲜事物降低了我们的程序效率?有网友指出评论一个特性或者方法的效率如何,唯一的判定标准就是实测

切入主题,按照以下代码,来结束你对dynamic的效率怀疑吧!!!

  1、新建测试类:

 
 
public class TestClass
{
public string TestProperty { get ; set ; }
}

  2、控制台程序进行效率测试代码:

 
 
static void Main( string [] args)
{
int times = 1000000 ;

string value = " Dynamic VS Reflection 上海企业网站制作="color: #800000;">" ;

// reflection 测试开始
TestClass testTypeByReflection = new TestClass();
Stopwatch watch1
= Stopwatch.StartNew();
var prop上海网站建设erty
= typeof (TestClass).GetProperty( " TestProperty " );
for (var i = 0 ; i < times; i ++ )
{
property.SetValue(testTypeByReflection, value,
null 上海徐汇企业网站制作 style="color: #000000;">);
}
Console.WriteLine(
string .Format( " Reflection耗时:{0} 毫秒 " , watch1.ElapsedMilliseconds));


// dynamic 测试开始
Stopwatch watch2 = Stopwatch.StartNew();
dynamic testTypeByDynamic
= new TestClass();
for ( int i = 0 ; i < times; i ++ )
{
testTypeByDynamic.TestProperty
= value;
}
Console.WriteLine(
string .Format( " Dynamic耗时:{0} 毫秒 " , watch2.ElapsedMilliseconds));

Console.ReadLine();
}

  3、测试TestClass类,开始 dynamic VS reflection 测试结果如下

  怎样,dynamic 比起reflection 够快吧?!

  最后希望本篇文章可以给您带来帮助,如有不足之处欢迎指出,谢谢!

目录
相关文章
|
4月前
分享一份 .NET Core 简单的自带日志系统配置,平时做一些测试或个人代码研究,用它就可以了
分享一份 .NET Core 简单的自带日志系统配置,平时做一些测试或个人代码研究,用它就可以了
|
6月前
|
机器学习/深度学习 JSON 测试技术
CNN依旧能战:nnU-Net团队新研究揭示医学图像分割的验证误区,设定先进的验证标准与基线模型
在3D医学图像分割领域,尽管出现了多种新架构和方法,但大多未能超越2018年nnU-Net基准。研究发现,许多新方法的优越性未经严格验证,揭示了验证方法的不严谨性。作者通过系统基准测试评估了CNN、Transformer和Mamba等方法,强调了配置和硬件资源的重要性,并更新了nnU-Net基线以适应不同条件。论文呼吁加强科学验证,以确保真实性能提升。通过nnU-Net的变体和新方法的比较,显示经典CNN方法在某些情况下仍优于理论上的先进方法。研究提供了新的标准化基线模型,以促进更严谨的性能评估。
177 0
|
7月前
|
机器学习/深度学习 算法 数据可视化
MATLAB基于深度学习U-net神经网络模型的能谱CT的基物质分解技术研究
MATLAB基于深度学习U-net神经网络模型的能谱CT的基物质分解技术研究
|
机器学习/深度学习 数据采集 存储
【3-D深度学习:肺肿瘤分割】创建和训练 V-Net 神经网络,并从 3D 医学图像中对肺肿瘤进行语义分割研究(Matlab代码实现)
【3-D深度学习:肺肿瘤分割】创建和训练 V-Net 神经网络,并从 3D 医学图像中对肺肿瘤进行语义分割研究(Matlab代码实现)
274 0
.Net Micro Framework研究—Digi开发板初探
写的比较基础全面,由于我们北航的研发团队先研究了Digi的开发板,所以直到今天Digi开发板才到我的手上,我的《Micro Framework研究》系列文章以后也会陆续推出
743 0
.Net Micro Framework研究—IO读写
试验平台:Digi MF开发板
469 0
.Net Micro Framework研究—串口操作
试验平台:Digi MF开发板,Digi提供的示例中包含了串口的示例程序
583 0
|
网络协议
.Net Micro Framework研究—TCP/IP通信
关于网络通信方面,Digi提供了两个程序,一个是TCP Server运行在Digi的开发板上,一个是TCP Client程序,运行在PC上,通过网络,上位机很容易控制Digi开发的IO信号
678 0
.Net Micro Framework研究—模拟器改造
由于Digi提供的开发板没有LCD显示屏,所以有关绘图方面的操作,只好在模拟器上进行了。
571 0