RazorEngine性能研究(反射的延深)

先说下结论

1)RazorEngine 确实很慢,编译过程特别慢,编译过后仍不适合大量重复调用的情况(一次调用可以接受)。

2 )   RazorEngine 和 asp.net mvc 里的Razor 的关系目前不清楚,所以这里的结论不代表asp.net mvc慢。

3).net 4.6里的反射性能较.net 2.0 略有提升,大概反射赋值的性能由原生赋值的1/5 提升到1/4。

这里测试RazorEngine时,实现了一个对象属性赋值器:

  1. using System.Diagnostics;
  2. using RazorEngine;
  3. using RazorEngine.Templating;
  1. //脚本化的C#想写对还是有点麻烦的,还好Razor能给出有用的错误信息。
  2. public class RazorPropertySetter<TEntity> where TEntity :class
  3. {
  4. string PropertyName;
  5. bool Inited = false;
  6. private RazorPropertySetter(){ }
  7. public static RazorPropertySetter<TEntity> Create( string propertyName)
  8. {
  9. RazorPropertySetter<TEntity> rs = new RazorPropertySetter<TEntity>();
  10. rs.PropertyName = propertyName;
  11. return rs;
  12. }
  13. public void Set(TEntity entity , object value)
  14. {
  15. string cacheKey = entity.GetType().FullName + "--" + this.PropertyName;
  16. DynamicViewBag viewBag = new DynamicViewBag();
  17. viewBag.AddValue("PropertyValue", value);
  18. if (Inited == false)
  19. {
  20. string template = "@{Model."+PropertyName+ "= ViewBag.PropertyValue;}";
  21. Engine.Razor.RunCompile(template, cacheKey, typeof(TEntity), entity,viewBag);
  22. Inited = true;
  23. }
  24. else
  25. {
  26. Engine.Razor.Run(cacheKey, typeof(TEntity), entity, viewBag);
  27. }
  28. }
  29. }
  1. //测试用类
  2. public class TestData
  3. {
  4. public string Title { get; set; }
  5. }
  1. //测试代码
  2. TestData data = new TestData();
  3. data.Title = "V1";
  4. RazorPropertySetter<TestData> setTitle = RazorPropertySetter<TestData>.Create("Title");
  5. Stopwatch watch = new Stopwatch();
  6. watch.Start();
  7. setTitle.Set(data, "V00");
  8. watch.Stop();

性能测试结果:

有时间的时候再研究下Script.net的性能。

来自为知笔记(Wiz)

时间: 2025-01-12 06:16:54

RazorEngine性能研究(反射的延深)的相关文章

MYSQL开发性能研究&mdash;&mdash;批量插入的优化措施

一.我们遇到了什么问题 在标准SQL里面,我们通常会写下如下的SQL insert语句. INSERT INTO TBL_TEST (id) VALUES(1);   很显然,在MYSQL中,这样的方式也是可行的.但是当我们需要批量插入数据的时候,这样的语句却会出现性能问题.例如说,如果有需要插入100000条数据,那么就需要有100000条insert语句,每一句都需要提交到关系引擎那里去解析,优化,然后才能够到达存储引擎做真的插入工作. 正是由于性能的瓶颈问题,MYSQL官方文档也就提到了使

2019-11-29-C#-性能分析-反射-VS-配置文件-VS-预编译

原文:2019-11-29-C#-性能分析-反射-VS-配置文件-VS-预编译 title author date CreateTime categories C# 性能分析 反射 VS 配置文件 VS 预编译 lindexi 2019-11-29 10:13:17 +0800 2018-10-15 20:48:40 +0800 C# 性能测试 本文分析在 C# 中使用反射和配置文件和预编译做注入的性能,本文的数据是为预编译框架,开发高性能应用 - 课程 - 微软技术暨生态大会 2018 - w

LuaJ 调用java方法性能研究

先简单写一下: lua调用java的方法,在luaJ中有两种. 1 使用官方提供的luaJava库 local ins = luajava.newInstance( "com.test.lj.TestClass");ins:test() 2 自己绑定方法,采用类似原版lua的方式将方法 local ins = TestClass.new() --new方法自己绑定 ins:test() 哪种方法好? 结论: 令人惊讶的是,luajava库反射调用的性能在某些情况下,竟然比java原生绑

C#使用反射(Reflection)实现深复制与浅复制

原文路径:https://blog.csdn.net/qq_28839293/article/details/79487294 1.浅复制: class Program { public static void Main(string[] args) { var classA1 = new ClassA { a = 1, b = "haha", d = new ClassB{ c ="haha" } }; var classA2 = (ClassA)classA1.

MYSQL开发性能研究&mdash;&mdash;INSERT,REPLACE,INSERT-UPDATE性能比较

一.为什么要有这个实验 我们的系统是批处理系统,类似于管道的架构.而各个数据表就是管道的两端,而我们的程序就类似于管道本身.我们所需要做的事情无非就是从A表抽取数据,经过一定过滤.汇总等操作放置到B表.如果出现了错误,那么就从重新跑这一个管道.所以说,我们的系统其实根本就不要什么事务性,无非就是挂了把表给TRUNCATE(或者有条件地DELETE)一下,然后重跑就行了. 这样一来,对于select语句就相对比较容易,基本上不需要做JOIN操作.然而对于写操作就有一些要求.比如说,需要处理主键重复

HBase学习笔记1-HConnection性能研究

使用Java API与HBase集群交互时,需要构建HTable对象,使用该对象提供的方法来进行插入/删除/查询等操作.要创建HTable对象,首先要创建一个带有HBase集群信息的配置对象Configuration conf,其一般创建方法如下: Configuration conf = HBaseConfiguration.create(); //设置HBase集群的IP和端口 conf.set("hbase.zookeeper.quorum", "10.172.1.61

原 .NET/C# 反射的的性能数据,以及高性能开发建议(反射获取 Attribute 和反射调用方法)

大家都说反射耗性能,但是到底有多耗性能,哪些反射方法更耗性能:这些问题却没有统一的描述. 本文将用数据说明反射各个方法和替代方法的性能差异,并提供一些反射代码的编写建议.为了解决反射的性能问题,你可以遵循本文采用的各种方案. 本文内容 反射各方法的性能数据 反射的高性能开发建议 创建类型的实例 反射获取 Attribute 反射调用公共 / 私有方法 使用预编译框架 附本文性能测试所用的代码 所有反射相关方法 IsDefined 和 GetCustomAttribute 的专项比较 参考资料 反

App的网络环境测试和性能优化

1. 网络环境测试一般是先用网络损伤模拟仪或mock工具模拟常见的七种损伤和5种网络环境,然后再国内外城市采样的方式(带宽和延时)组合测试生成报告, 下面是一些统计图 2. 采样点的选择一般都是根据自己server收集的用户信息.如果新app就要参考近品/竞品或第三方的统计数据拍脑袋 3. 从测试的角度,应该建立实时监控的web portal.其实测试的目的除了保证产品发布的质量.更重要的是为优化提供依据,所以report最后一部分都是issue list 和optmize advice,当然测

泛型和反射

泛型和反射经常是一起工作的,所以就一次介绍吧. c# 是强类型语言,一般上函数的返回类型和参数的类型都是一早些好的,也就造成了很多时候不像js那样方便使用,不灵话. 所以呢就有了这个泛型,它可以让你的函数和参数在调用的时候才决定类型. public T abc<T>(T word) { return word; return default(T); //关键字default可以对引用类型返回nullAble,int类型返回0,初始化一个T的感觉啦 } abc<string>(&qu