zoukankan      html  css  js  c++  java
  • [非专业翻译] Mapster

    [非专业翻译] Mapster - 调试

    系列介绍

    [非专业翻译] 是对没有中文文档进行翻译的系列博客,文章由机翻和译者自己理解构成,和原文相比有所有不同,但意思基本一致。

    因个人能力有限,如有谬误之处还请指正,多多包涵。

    正文

    本文将说明 Mapster 如何调试映射

    步进调试

    这个插件允许使用Roslyn执行步进调试!

    步进调试就是默认 F11 快捷键的调试

    PM> Install-Package ExpressionDebugger
    
    如何使用

    在启动时或编译映射之前的任何地方添加以下代码:

    TypeAdapterConfig.GlobalSettings.Compiler = exp => exp.CompileWithDebugInfo();
    

    现在处于 DEBUG 模式时,可以步进调试映射代码:

    var dto = poco.Adapt<SimplePoco, SimpleDto>(); //<--- 你可以步进调试到这段代码中
    

    使用内部类或成员

    调试模式不支持 privateprotectedinternal

    查看映射逻辑

    通过 ToScript 方法可以查看 Mapster 生成的映射逻辑:

    var script = poco.BuildAdapter()
                    .CreateMapExpression<SimpleDto>()
                    .ToScript();
    

    在Visual Studio for Mac中调试映射

    在 Visual Studio for Mac 中进行步进映射调试,需要配置 EmitFiletrue

    var opt = new ExpressionCompilationOptions { EmitFile = true };
    TypeAdapterConfig.GlobalSettings.Compiler = exp => exp.CompileWithDebugInfo(opt);
    ...
    var dto = poco.Adapt<SimplePoco, SimpleDto>(); //<--- 你可以步进调试到这段代码中
    

    是否会对性能产生影响

    RELEASE 编译模式下,Roslyn 编译器比默认的动态编译快2倍,因此不必担心会出现性能下降问题。

    结果如下:

    Method Mean StdDev Error Gen 0 Gen 1 Gen 2 Allocated
    'Mapster 4.1.1' 115.31 ms 0.849 ms 1.426 ms 31000.0000 - - 124.36 MB
    'Mapster 4.1.1 (Roslyn)' 53.55 ms 0.342 ms 0.654 ms 31100.0000 - - 124.36 MB
    目前学习.NET Core 最好的教程 .NET Core 官方教程 ASP.NET Core 官方教程
    如果您认为这篇文章还不错或者有所收获,您可以点击右下角的【推荐】支持,或请我喝杯咖啡【赞赏】,这将是我继续写作,分享的最大动力!
    声明:原创博客!请在转载时在文章开头注明本人博客地址。如发现错误,欢迎批评指正。凡是转载于本人的文章,不能设置打赏功能,如有特殊需求请与本人联系!
  • 相关阅读:
    自己写的DBHelper感慨颇深
    23种设计模式:观察者模式,第一次对观察者模式理解的这么通透。
    自己用心写的 存储过程分页 给自己的平台用
    开篇成长的开始[废话一把]
    C# 中i++在ref参数调用下的有趣现象
    点点滴滴的成长[2011111]:理解C#修饰符
    点点滴滴的成长[2011114]:自定义config文件
    扩展方法在Json字符串转化中的应用
    jquery学习二:jquery性能优化
    javascript系列1:函数
  • 原文地址:https://www.cnblogs.com/staneee/p/14913801.html
Copyright © 2011-2022 走看看