首页
学习
活动
专区
圈层
工具
发布

来一点反射和Emit,让ORM的使用极度简化

图中的数据库用PDF.NET集成开发工具打开,该工具可以在官网找到下载地址。...找到该表后,在左边的表名称树节点或者右边的查询窗口,鼠标右键菜单上,找到生成实体类的功能,具体过程这里不做演示了,因为这不是本文的主题。...写Emit代码也不是想象中的那么复杂,基本过程就是先手工写好C#代码,编译得到Exe或者Dll,然后用ILDASM或反编译工具,得到IL代码,最后就是看着IL代码,用Emit一个个对应发出代码,就行了。..."ITableName" 这样的格式,那么需要调用 MapNewTableName方法指定 //((EntityBase)user).MapNewTableName("Table_User...当前功能已经在PDF.NET Ver 4.6.4.0525 版本实现,之前的版本,大家可以去开源项目下载:http://pwmis.codeplex.com 4,动态实体类的使用约束 这里说的“动态实体类

1.1K90
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【.NET8】访问私有成员新姿势UnsafeAccessor(下)

    这其实是出乎我的意料的,因为我认为它最多和直接访问私有成员的性能差不多,但是实际上它的性能比直接访问私有成员还要好,当然也有可能是统计的误差,0.0000ns这个尺度已经非常小了。...深入探究 看到这里我想大家都有很多疑问,实际上作者本人看到这里也是有很多的疑问,主要是这两个: 是什么原因让.NET社区想加入这个API? 它是如何做到访问私有成员的? 为什么性能会这么好?...的不同枚举做了校验,防止出现运行时崩溃的情况: 然后调用了 GenerateAccessor方法来生成IL: 在 GenerateAccessor里面就是使用Emit进行代码生成: 所以从JIT的实现来看...另外是关于NativeAOT的实现,首先修改了 NativeAotILProvider.cs这个类,这个类的主要作用就是在进行 NativeAot的时候提供IL给JIT预先编译使用: 关键也是在 GenerateAccessor...其实原因也是显而易见的,我们自己编写的Emit代码中间有一层 DynamicMethod的委托调用,增加了开销,而 UnsafeAccessor它直接就是一个 staticexternintGetValueUnsafe

    61510

    C# 对象哈希码

    为此,System.Object提供了GetHashCode,它能获取任何对象的Int32哈希码.如果你定义的类型重写了Equals方法,还应重写GetHashCode方法。...如果你的类型重写了Equals方法,但是没有重写GetHashCode方法,C#编译器会发出一条警告,提示你重写GetHashCode方法,之所以重写Equals方法的同时要求重写GetHashCode...的原因是由于在System.Collection.HashTable类型、System.Collection.Generic.Dictionary类型以及其他的一些集合的实现中,要求两个对象必须有相等的哈希值才被视为相等...自定义GetHashcode方法或许不是一件难事,但取决于数据类型和数据分布情况,可能并不容易设计出能返回良好分布值的哈希算法。...选择算法来计算类型实例的哈希码时,请遵守一下规则: 1、这个算法要提供良好的随机分布,使哈希表获得最佳的性能 2、可在算法中调用基类的GetHashCode方法,并包含它的返回值,但一般不要调用Object

    96850

    推荐一个快速反射调用的类

    本文转载:http://blog.csdn.net/jehnjehn/article/details/7086863 使用传统的.net反射机制,调用类的方法时,在调用频率大的情况下,会感觉速度很慢。...最近浏览卢彦的博客时,找到一个他改进后的反射调用类。试用以后感觉效率明显提高,特推荐给大家。作者重新实现了,反射调用方法,但是调用接口和.net原有方法一致。...而且调用时抛出的异常为所调用类的实际异常,不像传统方式返回为包装异常。...object), new Type[] { typeof(object), typeof(object[]) }, methodInfo.DeclaringType.Module);             ILGenerator...il.Emit(OpCodes.Castclass, type);             }         }         privatestaticvoid EmitBoxIfNeeded(ILGenerator

    63820

    .NET高级特性-Emit

    前言 在这个大数据/云计算/人工智能研发普及的时代,Python的崛起以及Javascript的前后端的侵略,程序员与企业似乎越来越青睐动态语言所带来的便捷性与高效性,即使静态语言在性能,错误检查等方面的优于静态语言...Emit含义为发出、产生的含义,这是.NET中的一组类库,命名空间为System.Reflection.Emit,几乎所有的.NET版本(Framework/Mono/NetCore)都支持Emit,可以实现用...第三条指令,call表示调用方法,参数为调用方法的方法信息,并把返回的结构压入栈中,使用的参数为之前已经入栈的“Hello World!”...)); //寻找Console的WriteLine方法 ilGenerator.Emit(OpCodes.Nop); ilGenerator.Emit(OpCodes.Ret); 4、创建委托并调用 /...五、小结 Emit的本质是使用高级语言生成IL代码,进而进行调用的的一组类库,依赖Emit我们可以实现用代码生成代码的操作,即编程语言的自举,可以有效弥补静态语言的灵活性的缺失。

    1.3K10

    如何快速编写和调试 Emit 生成 IL 的代码

    大家都知道反射的性能很差,通过缓存反射调用的方法则能够大幅提升性能。Emit 为我们提供了这项能力,我们能够在运行时生成一段代码,替代使用反射动态调用的代码,以提升性能。...---- 我们在解决什么问题? 之前我写过一篇创建委托以大幅度提高反射调用的性能的方法,不过此方法适用于预先知道方法参数和返回值类型的情况。如果我们在编译期不知道类型,那么它就行不通了。(原因?...如果我们能够在运行时动态地生成一段调用方法,那么这个调用方法将可以缓存下来供后续重复调用。如果我们使用 Emit,那么生成的方法与静态编写的代码是一样的,于是就能获得普通方法的性能。...string 已经换成了 int。...((TempClass) @this).TempProperty = (int) value; } 重新生成可以得到一个 exe,调用新写的 OutputPropertySetter 可以得到

    1.8K10

    .net 应用迁移到Mono 工具 (Moma)

    到http://www.mono-project.com/MoMA下载最新版本,解压后运行MoMA.exe,选择一个要分析的程序集,可以选择一组程序集一起分析,在程序集分析过程中,这个工具会分析程序集中的所有方法...MoMA会检查到的主要有下列四种问题 : Missing Methods MonoTodo NotImplementedException P/Invokes Missing Methods 该问题是因为使用的方法在...NotImplementedException 该问题是因为应用程序中存在会丢出NotImplementedException的方法。 P/Invokes 该问题是因为应用程序中存在着平台调用。...平台调用通常是用来调用非托管的方法,尤其是平台本身提供的方法。 命令行执行 MoMa从1.9版开始就已支持命令行执行的功能。...执行完后,在命令提示字符看不到任何信息,须自行开启报表查看,其报表会存放在MoMa目录下的Reports目录内。

    2K80

    dotnet C# 实现 GetHashCode 的方法

    本文来聊聊在重写某个类的 GetHashCode 方法时,可以如何实现 GetHashCode 的返回值 按照 GetHashCode 方法的原则,要求两个对象如果 Equals 返回 true 那么一定要求...当然,反过来不成立,也就是两个对象返回的 GetHashCode 的值相同,对象可以是不相等的 实现 GetHashCode 方法的方式有很多,最简单的就是通过调用基类的 GetHashCode 方法,...} 第二个方法就是通过 RuntimeHelpers 静态类的 GetHashCode 方法,代码如下 public override int GetHashCode()...{ return RuntimeHelpers.GetHashCode(this); } 如果调用的 base.GetHashCode 的 base 是 object...类型的,也就是调用了 object 的 GetHashCode 方法,其实和调用 RuntimeHelpers 的 GetHashCode 方法是相同的,因为在 object 方法里面的 GetHashCode

    87730

    CA1065:不要在意外的位置引发异常

    属性 Get 方法 属性基本上都是智能字段。 因此,其行为应尽可能类似于字段。 字段不会引发异常,属性也不应引发异常。 如果有一个引发异常的属性,可考虑将其设为方法。...Dispose 通常作为 finally 子句中清理逻辑的一部分调用。 因此,从 Dispose 显式引发异常将强制用户在 finally 子句内添加异常处理。...Dispose (false) 代码路径应始终不会引发异常,因为 Dispose 几乎都是从终结器调用的。 相等运算符 (==, !...隐式强制转换运算符 由于用户通常不知道已调用了隐式强制转换运算符,因此对它引发的异常会感到意外。 因此,隐式强制转换运算符不应引发异常。...对于前面列出的所有其他方法类型,可更改逻辑,使其不再必须引发异常。 何时禁止显示警告 如果冲突是由异常声明而不是引发的异常造成的,则可禁止显示此规则发出的警告。

    92120
    领券