Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
      • 安装
      • 使用
        • 基本用法
        • 自定义映射
        • 忽略属性
        • 映射集合
        • 性能优化
      • 结论
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 对象映射
一个大西瓜
2023-04-20
目录

EmitMapper

开源地址

Github:https://github.com/emitmapper/emitmapper (opens new window)

EmitMapper是一个开源的.NET映射库,它可以帮助开发人员更轻松地将数据从一种类型映射到另一种类型。它使用IL Emit技术来生成高效的映射代码,可以大大提高映射性能。在本文中,我们将介绍如何使用EmitMapper来实现类型映射。

# 安装

要使用EmitMapper,首先需要安装它。可以使用NuGet来安装EmitMapper。在Visual Studio中,右键单击您的项目并选择“管理NuGet程序包”。在NuGet管理器中搜索“EmitMapper”,然后单击“安装”。

您也可以手动安装EmitMapper。您可以在其GitHub存储库中找到源代码并将其添加到您的项目中。或者,您可以下载编译版本的库并将其添加到您的项目中。

# 使用

# 基本用法

要使用EmitMapper,需要创建一个Mapper对象,然后使用其Map方法将源对象映射到目标对象。以下是一个简单的示例:


using EmitMapper;

var mapper = ObjectMapperManager.DefaultInstance.GetMapper<Source, Destination>();
var source = new Source { Value = "Hello World" };
var destination = mapper.Map(source);
Console.WriteLine(destination.Value); // 输出 "Hello World"

上面的代码创建了一个Mapper对象,并使用其Map方法将源对象映射到目标对象。Mapper对象使用ObjectMapperManager类的GetMapper方法创建。GetMapper方法接受源类型和目标类型作为参数,并返回一个泛型Mapper对象。

在此示例中,我们还定义了Source和Destination类。源类具有一个名为Value的属性,目标类也具有一个名为Value的属性。映射操作将源对象的Value属性映射到目标对象的Value属性。

# 自定义映射

EmitMapper允许您定义自定义映射规则。例如,您可以定义一个规则,将一个字符串类型的值映射到一个枚举类型的值。以下是一个自定义映射规则的示例:


using EmitMapper;

var mapper = ObjectMapperManager.DefaultInstance.GetMapper<Source, Destination>(cfg =>
{
    cfg.ConvertUsing<string, MyEnum>(str => (MyEnum)Enum.Parse(typeof(MyEnum), str));
});

var source = new Source { Value = "Value1" };
var destination = mapper.Map(source);
Console.WriteLine(destination.Value); // 输出 "MyEnum.Value1"

在上面的示例中,我们使用Mapper对象的Configure方法来定义自定义映射规则。在这种情况下,我们定义了一个将字符串值映射到MyEnum类型值的规则。

# 忽略属性

EmitMapper允许您忽略源对象中的属性,从而在映射操作中排除这些属性。以下是一个示例:


using EmitMapper;

var mapper = ObjectMapperManager.DefaultInstance.GetMapper<Source, Destination>(cfg =>
{
    cfg.IgnoreMembers<Source>(s => s.Value);
});

在上面的示例中,我们使用Mapper对象的Configure方法来忽略源对象中的Value属性。这将在映射操作中排除Value属性。

# 映射集合

EmitMapper还允许您映射集合类型。以下是一个示例:


using EmitMapper;

var mapper = ObjectMapperManager.DefaultInstance.GetMapper<Source, Destination>(cfg =>
{
    cfg.MapCollectionMembers<Source, Destination, string>(s => s.Collection, d => d.Collection);
});

var source = new Source { Collection = new List<string> { "Value1", "Value2", "Value3" } };
var destination = mapper.Map(source);
Console.WriteLine(string.Join(", ", destination.Collection)); // 输出 "Value1, Value2, Value3"

在上面的示例中,我们使用Mapper对象的Configure方法来映射源对象中的Collection属性到目标对象的Collection属性。我们还指定了集合元素的类型为字符串类型。

# 性能优化

EmitMapper使用IL Emit技术来生成高效的映射代码。但是,在某些情况下,可能需要进一步优化映射性能。以下是一些优化技巧:

  • 缓存Mapper对象:创建Mapper对象是一个开销较大的操作,因此最好将其缓存以避免重复创建。
  • 预编译映射代码:EmitMapper允许您预编译映射代码以提高性能。您可以使用Mapper对象的Compile方法来编译映射代码,并将其缓存以供以后使用。
  • 使用快速反射:EmitMapper使用反射来访问属性和字段。但是,它还提供了一个选项,即使用快速反射。快速反射使用表达式树来生成访问器方法,从而提高访问性能。

以下是一个示例:


using EmitMapper;
using EmitMapper.MappingConfiguration;
using EmitMapper.Utils;

var config = new DefaultMapConfig()
    .UseDestinationValuePreSealedClass(true)
    .UseDestinationValueWhenNull(true)
    .UseParallelMapper(true)
    .CacheEnabled(true)
    .CreateMapper();

var mapper = ObjectMapperManager.DefaultInstance.GetMapper<Source, Destination>(config);

var source = new Source { Value = "Hello World" };

var destination = new Destination();
FastDeepCloner.DeepCloner.Copy(source, destination, mapper);
Console.WriteLine(destination.Value); // 输出 "Hello World"

在上面的示例中,我们使用了EmitMapper提供的快速反射功能,它通过表达式树生成访问器方法来访问属性和字段。

# 结论

EmitMapper是一个非常有用的.NET映射库,它可以帮助您更轻松地将数据从一种类型映射到另一种类型。使用EmitMapper,您可以轻松地定义自定义映射规则,映射集合类型,并优化映射性能。希望本文能够帮助您更好地理解EmitMapper并开始使用它。

上次更新: 2023/04/26, 22:10:06
AutoMapper
AgileMapper

← AutoMapper AgileMapper→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式