public class DataModule : IModule
{
public void Configure(IMapperConfigurationExpression cfg)
{
//cfg.CreateMap<ApproveAtcPo, ApproveAtcVo>().ReverseMap(); }
}
         /// <summary>
/// 注册需要转换的类型
/// </summary>
private PoMapper()
{
AutoMapper.Mapper.Initialize(cfg =>
{
//多模块注册方式
new DataModule().Configure(cfg);
new AliasModule().Configure(cfg);
});
}
     public class MapperTool
{
private static volatile MapperTool mapper = null;
private static object syncRoot = new Object();
public static readonly List<Type> typeList = null;
/// <summary>
/// 注册需要转换的类型
/// </summary>
private MapperTool()
{
Mapper.Initialize(cfg =>
{
//指定不同属性映射demo
//cfg.CreateMap<auth_userVo, t_auth_user>()
// .ReverseMap()
// .ForMember(dest => dest.id, opt => opt.MapFrom(src => src.rid))
// .ForMember(dest => dest.update, opt => opt.MapFrom(src => src.create)); });
//验证是否所有字段都转换了
//Mapper.Configuration.AssertConfigurationIsValid();
} private MapperTool(List<Type[]> TypeList)
{
Mapper.Initialize(cfg =>
{
foreach (var type in TypeList)
{
cfg.CreateMap(type[], type[]).ReverseMap();
}
});
} /// <summary>
/// 初始化注册Mapper
/// </summary>
public static MapperTool Instance
{
get
{
if (mapper == null)
{
lock (syncRoot)
{
if (mapper == null)
{
mapper = new MapperTool();
} }
}
return mapper;
}
} /// <summary>
/// 传入需要转换的对象
/// </summary>
/// <typeparam name="F">需要转换的对象类型</typeparam>
/// <typeparam name="T">转换目标对象类型</typeparam>
/// <param name="f">需要转换的对象</param>
/// <returns>目标对象</returns>
public T Map<F, T>(F f)
where F : new()
where T : new()
{
return Mapper.Map<F, T>(f);
}
}

封装一个Automapper单例的更多相关文章

  1. 封装MySQL的单例,连接数据库并对数据进行增删改查操作

    单例: 一个类只能有一个对象 应用场景:多次请求数据库只需要一个连接对象. 实现:三私一公 1.私有的静态属性用来保存对象的单例2.私有的构造方法用来阻止在类的外部实例化3.私有的__clone阻止在 ...

  2. 基于Ant Design Vue封装一个表单控件

    开源代码 https://github.com/naturefwvue/nf-vue3-ant 有缺点本来是写在最后的,但是博文写的似乎有点太长了,估计大家没时间往下看,于是就把有缺点写在前面了,不喜 ...

  3. muduo网络库源码学习————线程本地单例类封装

    muduo库中线程本地单例类封装代码是ThreadLocalSingleton.h 如下所示: //线程本地单例类封装 // Use of this source code is governed b ...

  4. [iOS]封装单例类

    [iOS]封装单例类 今天在学习iOS的SQLite开发,发现在需要使用SQLite的每个视图中,都需要对数据库进行打开或关闭,觉得挺麻烦的:于是在想能否写个单例类对这些操作进行封(因以前一直在使用D ...

  5. Java单例设计模式(实现Java的一个类只有一个对象)

    单例设计模式的定义:单例设计模式是一种软件设计模式,在它的核心包含一个称为单例类的核心类. 核心便是希望一个类只有一个对象.  如何实现类在内存中只有一个对象呢? 第一步:构造私有:第二步:本身提供一 ...

  6. python__基础 : 类的__new__方法与实现一个单例

    __new__ : 这个方法的作用主要是创建一个实例,在创建实例时首先会调用 __new__方法 ,然后调用__init__对实例进行初始化, 如果想修改 __new__ 这个方法,那么最后要 ret ...

  7. Java设计模式之单例

    一.Java中的单例: 特点: ① 单例类只有一个实例 ② 单例类必须自己创建自己唯一实例 ③ 单例类必须给所有其他对象提供这一实例 二.两种模式: ①懒汉式单例<线程不安全> 在类加载时 ...

  8. Swift - 简单封装一个工具类模板

    创建模板类(封装一个类) 例1:新建一个名字叫做 Product 的类 Product.swift File 的内容 class Product { var name: String var desc ...

  9. 属性传值,协议传值,block传值,单例传值四种界面传值方式

    一.属性传值 对于属性传值而言,相对于其它的三种 方法来说,是最基础,最简单的一种 方法,但,属性传值 有很大的局限性,因为是适用于第一个界面向第二个界面传 值,第二个向第三个界面传值等等.N界面向N ...

随机推荐

  1. Task ‘run’ not found in root project

    问题现象: Task 'run' not found in root project 'springframework'. 问题原因: 没有在gradle.build文件中添加如下配置, mainCl ...

  2. UVa 658 - It's not a Bug, it's a Feature!(Dijkstra + 隐式图搜索)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  3. UVa 1262 - Password(解码)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  4. 安装最新版的wampserver,可以兼容php5和php7

    本文介绍的wamp是Windows+Apache+MySQL+PHP+phpMyAdmin,主要应用于开发环境[一键安装包,简单好用]. 这是运行在Windows系统下的官方安装包,可以快速的搭建属于 ...

  5. 2.spring:集合属性

    1.list  配置java.util.List类型的属性,需要指定<list>标签,在标签里面包含有一些元素,这些标签 可以通过<value>指定简单的常量值,通过<r ...

  6. 在Windows 7和10上显示上次登录帐户信息

    组策略: 计算机配置->管理模板->Windows组件->Windows登录选项 现在注销并重新登录以查看会发生什么. 在进入桌面之前,用户必须确认该消息 注册表: 打开: &quo ...

  7. CQRS轻量级框架【CQRSlite】学习使用小记

    前言 这几天在研究DDD和CQRS.快把我绕晕了.发现国外的好文质量还是挺高的.之所以先体验CQRSlite这个小框架,是因为看了一位大神写的文章:https://www.codeproject.co ...

  8. logback配置与使用(2)

    转载:yaoh371 的logback.xml常用配置 <?xml version="1.0" encoding="UTF-8"?> <!-- ...

  9. 十四、详述 IntelliJ IDEA 提交代码前的 Code Analysis 机制

    在我们用 IntelliJ IDEA 向 SVN 或者 Git 提交代码的时候,IntelliJ IDEA 提供了一个自动分析代码的功能,即Perform code analysis: 如上图所示,当 ...

  10. Css中路径data:image/png;base64的用法详解 (转载)

    大家可能注意到了,网页上有些图片的src或css背景图片的url后面跟了一大串字符,比如: background-image:url(data:image/png;base64, iVBORw0KGg ...