• 19.AutoMapper 之开放式泛型(Open Generics)


     

    开放式泛型(Open Generics)

    AutoMapper可以支持开放式泛型的映射。为开放式泛型创建映射:

    public class Source<T> {
        public T Value { get; set; }
    }
    
    public class Destination<T> {
        public T Value { get; set; }
    }
    
    // 创建映射
    Mapper.Initialize(cfg => cfg.CreateMap(typeof(Source<>), typeof(Destination<>)));
    

    你不需要为封闭式泛型类型创建映射。AutoMapper在运行时将应用开放式泛型映射的配置到封闭式泛型映射中:

    var source = new Source<int> { Value = 10 };
    
    var dest = mapper.Map<Source<int>, Destination<int>>(source);
    
    dest.Value.ShouldEqual(10);
    

    因为C#只允许封闭式泛型类型参数,所以必须使用System.Type版本的CreateMap创建你的开放式泛型映射。你可以使用所有可用的映射配置,并且开放式泛型配置将在运行时应用于封闭类型映射。AutoMapper在配置验证期间将跳过开放式泛型映射,因为之后仍然可以创建不转换的闭合类型,例如Source <Foo> - > Destination <Bar>,其中没有从Foo到Bar的转换。

    你也可以创建一个开放式泛型的转换器:

    Mapper.Initialize(cfg =>
       cfg.CreateMap(typeof(Source<>), typeof(Destination<>)).ConvertUsing(typeof(Converter<>)));
    

    AutoMapper还支持具有任意数量泛型参数的开放式泛型类型转换器:

    Mapper.Initialize(cfg =>
       cfg.CreateMap(typeof(Source<>), typeof(Destination<>)).ConvertUsing(typeof(Converter<,>)));
    

    来自Source的闭合类型将是第一个泛型参数,而'Destination的闭合类型将是Converter <,>`的第二个参数。

    码字不易,动动手指给个赞吧

  • 相关阅读:
    Mybatis分页插件PageHelper使用
    JAVA面试笔记
    基于Fusioncharts的报表统计
    微信支付开发流程
    Java 使用 Jxl 实现 Excel 导入导出
    从navicat中导入sql文件过大:Got a packet bigger than 'max_allowed_packet' bytes
    一个故事告诉你比特币的原理及运作机制
    Linux和Windows下tomcat开机自启动设置
    Linux下安装MySQL
    ubuntu 13.10使用fcitx输入法
  • 原文地址:https://www.cnblogs.com/zengpeng/p/11059974.html
Copyright © 2020-2023  润新知