-
C#教程之System.Linq.Dynamic字符串转委托
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
以前一直想着有没有一个方法能够把字符串直接转化成函数的,刚好有需求就找了下,还真有。
微软地址:https://docs.microsoft.com/en-us/previous-versions/bb894665(v=msdn.10)?redirectedfrom=MSDN
一、安装
NuGet程序管理器,System.Linq.Dynamic
二、应用与性能:
class Model { public string name; public Model(string s) { name = s; } } //创建示例数据: Model m1 = new Model("111"); Model m2 = new Model("222"); List<Model> list = new List<Model>(); list.Add(m1); list.Add(m2); //普通Lambda list.Where(m=>m.name.StartsWith("1")).ToList(); //DynamicQuery list.AsQueryable().Where("name.StartsWith(@0) ", "1").ToList();
效果一样,但性能开销不同,各执行1000次循环:
尝试其他方法,ParseLambda ,把条件单独出来获得函数委托,再调用Linq的Where。
var lambda = DynamicExpression.ParseLambda<Model, bool>("name.StartsWith(@0)", "1"); var fun = expfun.Compile(); list.Where(s => fun(s)).ToList();
运行1000次看下,虽然和原生的还有差距,但已经在可以接受的范围内了。
三、其他方法:
//DynamicExpression中还有CreateClass可以实现类的动态创建: var tp = DynamicExpression.CreateClass(new DynamicProperty("a", typeof(decimal)), new DynamicProperty("b", typeof(decimal))); var obj = Activator.CreateInstance(tp); tp.GetProperty("a").SetValue(obj, 12m,null); tp.GetProperty("b").SetValue(obj, 10m, null); //此时一个包含a,b属性的实例obj已经创建好,这时利用ParseLambda<T,S>就可以做到很多事情,比如根据字符串进行运算。 var lambda = DynamicExpression.ParseLambda(tp,typeof(decimal),"a*b+2"); var fun = lambda.Compile(); decimal sum = (decimal)fun.DynamicInvoke(obj); //其他的比如根据已知类型也可进行一些想要的操作: DynamicExpression.ParseLambda<Model, string>("@0 + name", "名字:");
有时string转成函数执行还是很方便的,用这个做一个计算器小程序的话,运算符解析什么的就完全不需要考虑了。
参考链接:
https://www.cnblogs.com/David-Qian/archive/2009/01/22/1379596.html
https://blog.csdn.net/xuchen_wang/article/details/90749743
栏目列表
最新更新
C# 面向对象
假设客车的座位数是9行4列,使用二维数
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日