一个比 AutoMapper 更快的模型映射的组件 Mapster
下面是官方的性能测试 Demo,感性的也可以去 Github 上下载。
贴出代码目的是如果后期直接从自己的博客中在线看。
using System;
using System.Collections.Generic;
using System.Diagnostics;
using AutoMapper;
using Benchmark.Classes;
using Mapster;
using FastExpressionCompiler;
using System.Linq.Expressions; namespace Benchmark
{
class Program
{
static double sAM;
static double sMP;
static double sMF;
static double sEM; static Func<LambdaExpression, Delegate> defaultCompiler = TypeAdapterConfig.GlobalSettings.Compiler; static void Main(string[] args)
{
try
{
Mapper.Initialize(cfg =>
{
cfg.CreateMap<Foo, Foo>();
cfg.CreateMap<Address, Address>();
cfg.CreateMap<Address, AddressDTO>();
cfg.CreateMap<Customer, CustomerDTO>();
});
TestSimpleTypes();
TestComplexTypes(); Console.WriteLine();
Console.WriteLine($"======================================================================================");
Console.WriteLine($"| Tests | Time (ms) | Slower than Mapster | Slower than Mapster + FEC |");
Console.WriteLine($"======================================================================================");
Console.WriteLine($"| Mapster v3.1.8 | { sMP,9} | { sMP / sMP,18:N2}X | { sMP / sMF,24:N2}X |");
Console.WriteLine($"| Mapster v3.1.8 + FEC | { sMF,9} | { sMF / sMP,18:N2}X | { sMF / sMF,24:N2}X |");
Console.WriteLine($"| Automapper v7.0.1 | { sAM,9} | { sAM / sMP,18:N2}X | { sAM / sMF,24:N2}X |");
Console.WriteLine($"| ExpressMapper v1.9.1 | { sEM,9} | { sEM / sMP,18:N2}X | { sEM / sMF,24:N2}X |");
Console.WriteLine($"======================================================================================");
Console.WriteLine();
} finally
{
Console.WriteLine("Finish");
Console.ReadLine();
}
} static void TestSimpleTypes()
{
Console.WriteLine("Test 1 : Simple Types");
Console.WriteLine("Competitors : Mapster, ExpressMapper, AutoMapper"); var foo = GetFoo(); TestSimple(foo, ); TestSimple(foo, ); TestSimple(foo, ); TestSimple(foo, ); //Console.WriteLine();
//Console.WriteLine("Automapper to Mapster ratio: " + (AutomapperTime / MapsterTime).ToString("###.00") + " X slower");
//Console.WriteLine("ExpressMapper to Mapster ratio: " + (ExpressMapperTime / MapsterTime).ToString("###.00") + " X slower");
//Console.WriteLine(); } static void TestComplexTypes()
{
Console.WriteLine();
Console.WriteLine(); Console.WriteLine("Test 2 : Complex Types");
Console.WriteLine("Competitors : Mapster, ExpressMapper, AutoMapper"); var customer = GetCustomer(); //TypeAdapterConfig.GlobalSettings.DestinationTransforms.Upsert<Guid>(x => x); //ObjectMapperManager.DefaultInstance.GetMapper<Customer, CustomerDTO>().Map(customer); Test(customer, ); Test(customer, ); Test(customer, ); Test(customer, ); Test(customer, ); //Console.WriteLine();
//Console.WriteLine("Automapper to Mapster ratio: " + (AutomapperTime/MapsterTime).ToString("###.00") + " X slower");
//Console.WriteLine("ExpressMapper to Mapster ratio: " + (ExpressMapperTime/MapsterTime).ToString("###.00") + " X slower");
//Console.WriteLine();
} static void Test(Customer item, int iterations)
{
Console.WriteLine(); Console.WriteLine("Iterations : {0}", iterations); //TestCustomerNative(item, iterations); TypeAdapterConfig.GlobalSettings.Compiler = defaultCompiler; //switch compiler
TypeAdapterConfig.GlobalSettings.Compile(typeof(Customer), typeof(CustomerDTO)); //recompile
item.Adapt<Customer, CustomerDTO>(); //exercise
TestMapsterAdapter<Customer, CustomerDTO>(item, iterations, ref sMP); TypeAdapterConfig.GlobalSettings.Compiler = exp => exp.CompileFast(); //switch compiler
TypeAdapterConfig.GlobalSettings.Compile(typeof(Customer), typeof(CustomerDTO)); //recompile
item.Adapt<Customer, CustomerDTO>(); //exercise
TestMapsterAdapter<Customer, CustomerDTO>(item, iterations, ref sMF); ExpressMapper.Mapper.Map<Customer, CustomerDTO>(item); //exercise
TestExpressMapper<Customer, CustomerDTO>(item, iterations, ref sEM); Mapper.Map<Customer, CustomerDTO>(item); //exercise
TestAutoMapper<Customer, CustomerDTO>(item, iterations, ref sAM);
} static void TestSimple(Foo item, int iterations)
{ Console.WriteLine(); Console.WriteLine("Iterations : {0}", iterations); TypeAdapterConfig.GlobalSettings.Compiler = defaultCompiler; //switch compiler
TypeAdapterConfig.GlobalSettings.Compile(typeof(Foo), typeof(Foo)); //recompile
item.Adapt<Foo, Foo>(); //exercise
TestMapsterAdapter<Foo, Foo>(item, iterations, ref sMP); TypeAdapterConfig.GlobalSettings.Compiler = exp => exp.CompileFast(); //switch compiler
TypeAdapterConfig.GlobalSettings.Compile(typeof(Foo), typeof(Foo)); //recompile
item.Adapt<Foo, Foo>(); //exercise
TestMapsterAdapter<Foo, Foo>(item, iterations, ref sMF); //TestValueInjecter<Foo, Foo>(item, iterations); ExpressMapper.Mapper.Map<Foo, Foo>(item); //exercise
TestExpressMapper<Foo, Foo>(item, iterations, ref sEM); Mapper.Map<Foo, Foo>(item); //exercise
TestAutoMapper<Foo, Foo>(item, iterations, ref sAM);
} static void TestCustomerNative(Customer item, int iterations)
{
Console.WriteLine("Handwritten Mapper:\t" + Loop<Customer>(item, get =>
{
var dto = new CustomerDTO(); dto.Id = get.Id;
dto.Name = get.Name;
dto.AddressCity = get.Address.City; dto.Address = new Address() { Id = get.Address.Id, Street = get.Address.Street, Country = get.Address.Country, City = get.Address.City }; dto.HomeAddress = new AddressDTO() { Id = get.HomeAddress.Id, Country = get.HomeAddress.Country, City = get.HomeAddress.City }; dto.Addresses = new AddressDTO[get.Addresses.Length];
for (int i = ; i < get.Addresses.Length; i++)
{
dto.Addresses[i] = new AddressDTO() { Id = get.Addresses[i].Id, Country = get.Addresses[i].Country, City = get.Addresses[i].City };
} dto.WorkAddresses = new List<AddressDTO>();
foreach (var workAddress in get.WorkAddresses)
{
dto.WorkAddresses.Add(new AddressDTO() { Id = workAddress.Id, Country = workAddress.Country, City = workAddress.City });
} }, iterations));
} static void TestMapsterAdapter<TSrc, TDest>(TSrc item, int iterations, ref double counter)
where TSrc : class
where TDest : class, new()
{
var time = Loop(item, get => get.Adapt<TSrc, TDest>(), iterations);
Console.WriteLine("Mapster:\t\t" + time);
counter += time;
} static void TestExpressMapper<TSrc, TDest>(TSrc item, int iterations, ref double counter)
where TSrc : class
where TDest : class, new()
{
var time = Loop(item, get => ExpressMapper.Mapper.Map<TSrc, TDest>(get), iterations);
Console.WriteLine("ExpressMapper:\t\t" + time);
counter += time;
} static void TestAutoMapper<TSrc, TDest>(TSrc item, int iterations, ref double counter)
where TSrc : class
where TDest : class, new()
{
//if (iterations > 50000)
// Console.WriteLine("AutoMapper still working please wait..."); var time = Loop(item, get => Mapper.Map<TSrc, TDest>(get), iterations);
Console.WriteLine("AutoMapper:\t\t" + time);
counter += time;
} static long Loop<T>(T item, Action<T> action, int iterations = )
{
return Time(item, a =>
{
for (int i = ; i < iterations; i++)
{
action(a);
}
});
} static long Time<T>(T item, Action<T> action)
{
var sw = new Stopwatch();
sw.Start();
action(item);
sw.Stop();
return sw.ElapsedMilliseconds;
} #region Data static Customer GetCustomer()
{
Customer c = new Customer()
{
Address = new Address() { City = "istanbul", Country = "turkey", Id = , Street = "istiklal cad." },
HomeAddress = new Address() { City = "istanbul", Country = "turkey", Id = , Street = "istiklal cad." },
Id = ,
Name = "Eduardo Najera",
Credit = 234.7m,
WorkAddresses = new List<Address>()
{
new Address() {City = "istanbul", Country = "turkey", Id = , Street = "istiklal cad."},
new Address() {City = "izmir", Country = "turkey", Id = , Street = "konak"}
},
Addresses = new List<Address>()
{
new Address() {City = "istanbul", Country = "turkey", Id = , Street = "istiklal cad."},
new Address() {City = "izmir", Country = "turkey", Id = , Street = "konak"}
}.ToArray()
}; return c;
} static Foo GetFoo()
{
var o = new Foo
{
Name = "foo",
Int32 = ,
Int64 = ,
NullInt = ,
DateTime = DateTime.Now,
Doublen = ,
Foo1 = new Foo { Name = "foo one" },
Foos = new List<Foo>
{
new Foo {Name = "j1", Int64 = , NullInt = },
new Foo {Name = "j2", Int32 = , NullInt = },
new Foo {Name = "j3", Int32 = , NullInt = },
},
FooArr = new[]
{
new Foo {Name = "a1"},
new Foo {Name = "a2"},
new Foo {Name = "a3"},
},
IntArr = new[] { , , , , },
Ints = new[] { , , },
}; return o;
} #endregion }
}
谢谢浏览!
一个比 AutoMapper 更快的模型映射的组件 Mapster的更多相关文章
- 一个比NPM更快更安全可靠的JavaScript包管理工具——Yarn
yarn安装: npm intall -g yarn 查看安装是否成功: yarn -v yarn常用的命令以及和npm的对照如下: 更详细的请查看官方文档
- linux 下程序员专用搜索源码用来替代grep的软件ack(后来发现一个更快的: ag), 且有vim插件的
发现一个比ack更快更好用的: https://github.com/ggreer/the_silver_searcher , 使用时命令为ag,它是基于ack的代码二次开发的,所有使用方法基本 ...
- 比NGINX更快:nginx-1.15.5 vs mongols-1.2.3
nginx是多进程web服务器的优秀代表. 本文要用mongols-1.2.3实现一个比nginx更快的多进程的web服务器. mongols是C++ 服务器基础设施库, 它的主要特性如下: tcp ...
- 修复bug有哪些更快的技术?做好这6点就够了
你有没有想过为什么有时修复错误似乎比它应该花费更长的时间?当你终于找到问题时,事实证明你所需要的只是一个小小的改变.然而,花了很多时间才能找到正在发生的事情.这种情况比我想象的更频繁. 另一方面,当您 ...
- MindSpore模型精度调优实战:如何更快定位精度问题
摘要:为大家梳理了针对常见精度问题的调试调优指南,将以"MindSpore模型精度调优实战"系列文章的形式分享出来,帮助大家轻松定位精度问题,快速优化模型精度. 本文分享自华为云社 ...
- EdgeFormer: 向视觉 Transformer 学习,构建一个比 MobileViT 更好更快的卷积网络
前言 本文主要探究了轻量模型的设计.通过使用 Vision Transformer 的优势来改进卷积网络,从而获得更好的性能. 欢迎关注公众号CV技术指南,专注于计算机视觉的技术总结.最新技术跟 ...
- android开发者您还在为模拟器犯愁吗?神级android模拟器---Genymotion一个更快、接近完美的模拟器……
摘要:Android系统非常特别,App须要进行模拟化測试.即使这样仍然有解决的办法---虚拟化技术. 之前的模拟器比方eclipse自带的是非常慢的一种,并且模拟器的版本号并非最新的.开机.能够说差 ...
- LSM树——LSM 将B+树等结构昂贵的随机IO变的更快,而代价就是读操作要处理大量的索引文件(sstable)而不是一个,另外还是一些IO被合并操作消耗。
Basic Compaction 为了保持LSM的读操作相对较快,维护并减少sstable文件的个数是很重要的,所以让我们更深入的看一下合并操作.这个过程有一点儿像一般垃圾回收算法. 当一定数量的ss ...
- ZeroMQ一个更小、更快、更简单的智能传输层协议
这个githube上的教程是非常好的,是个中文翻译,大家直接学这个就行 https://github.com/anjuke/zguide-cn/tree/master/bin 原文地址: https: ...
随机推荐
- MongoDB for OPS 04:备份恢复
写在前面的话 和 MySQL 一样,mongodb 也是需要将数据进行备份的,毕竟天有不测风云,谁也不知道哪天机器就炸了. 备份恢复 mongodb 提供了两种备份恢复手段:mongoexport / ...
- SpringBoot中数据加密存储和获取后解密展示AttributeConverter的实现
1. 需求: 数据库存入数据的时候要加密处理,不同的字段加密方式不同. 界面上展示的时候要解密处理,解密方式相同. 2. 实现方案一: 定义公共的加密解密方法,然后在对应的字段上重写他的getset方 ...
- Http协议(自己的一些小小的总结,方便日后学习揣摩)
从2019年6月中旬开始学习JAVA已经差不多6个月了,也算是差不多半只脚踏进了JAVA的大门,没有老师带,遇到问题就要自己查百度,搜博客,去给各个大佬私信留言,也不知道看不看的见. 看了很多大佬的视 ...
- HTTP面试常见题
1.HTTP2.0.1.1.1.0.0.9的区别? 答:HTTP0.9:是HTTP协议的第一个版本,只允许发送get请求,并且不支持请求头.一次请求对应一次响应.是短连接. HTTP1.0:相比于0. ...
- Java基础--注解、反射
一.注解(Annotation) 1.什么是注解? 从JDK5开始,Java增加了Annotation(注解),Annotation是代码里的特殊标记,这些标记可以在编译.类加载.运行时被读取,并执行 ...
- css 关于浮动float的使用以及清除浮动
float:none | left | right 默认值:none 适用于:所有元素 none:设置对象不浮动left:设置对象浮在左边right:设置对象浮在右边 当该属性不等于none引起对象浮 ...
- E203 itcm
E203 itcm是64Kb,所以地址总线为16位,2^16=64Kb, 数据线宽度为64 bits(8 bytes),所以address width是16-3=13bit,ram depth 是2^ ...
- JavaScript 错误异常
JavaScript 错误异常 错误异常语句 try 语句测试代码块中的错误 catch 语句处理错误 throw 语句允许自定义错误 finally 语句在错误异常语句后,必须执行的代码块 try ...
- [转]Outlook VBA自动处理邮件
本文转自:https://blog.csdn.net/hnwyllmm/article/details/44874331 需求描述公司里面每天都会有很多邮件,三分之一都是不需要看的,Outlook的过 ...
- Hibernate Validator Engine的用法
一.引入架包 maven地址 点击即可. <!-- https://mvnrepository.com/artifact/org.hibernate.validator/hibernate-v ...