[非专业翻译] 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
posted @ 2021-07-15 08:42  玩双截棍的熊猫  阅读(412)  评论(0编辑  收藏  举报