调试

June 21, 2021 · View on GitHub

步进调试

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

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

PM> Install-Package ExpressionDebugger
如何使用

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

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

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

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

image-20210613142212048

使用内部类或成员

调试模式不支持 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倍,因此不必担心会出现性能下降问题。

结果如下:

MethodMeanStdDevErrorGen 0Gen 1Gen 2Allocated
'Mapster 4.1.1'115.31 ms0.849 ms1.426 ms31000.0000--124.36 MB
'Mapster 4.1.1 (Roslyn)'53.55 ms0.342 ms0.654 ms31100.0000--124.36 MB