首页 > 其他 > 详细

适配者模式

时间:2017-06-24 17:47:40      阅读:226      评论:0      收藏:0      [点我收藏+]

适配者模式:在调用的接口已经确定,提供的接口也已经确定,但有写地方不匹配,就需要适配者模式来处理匹配,一般用在后期代码维护

主方法

namespace 适配模式
{
    class Program
    {
        static void Main(string[] args)
        {
            ISqlHelper s1 = new Sql();
            s1.Add();
            s1.Delete();
            s1.Update();
            s1.Search();

            ISqlHelper s2 = new AdapterLucene();
            s2.Add();
            s2.Delete();
            s2.Update();
            s2.Search();

            Console.ReadKey();
        }
    }
}

ISqlHelper接口

public interface ISqlHelper
    {
        void Add();
        void Delete();
        void Update();
        void Search();
    }

sql类

    public class Sql:ISqlHelper
    {
        public void Add()
        {
            Console.WriteLine("sql增加");
        }

        public void Delete()
        {
            Console.WriteLine("sql删除");
        }

        public void Update()
        {
            Console.WriteLine("sql修改");
        }

        public void Search()
        {
            Console.WriteLine("sql查询");
        }
    }

Lucene类

    /// <summary>
    /// 全表索引插件,没有更新方法
    /// </summary>
    public class Lucene
    {
        public void Add()
        {
            Console.WriteLine("Lucene增加");
        }

        public void Delete()
        {
            Console.WriteLine("Lucene删除");
        }

        public void Search()
        {
            Console.WriteLine("Lucene查询");
        }
    }

Lucene适配类

    /// <summary>
    /// 适配者模式:在调用的接口已经确定,提供的接口也已经确定,但有写地方不匹配
    /// 就需要适配者模式来处理匹配,一般用在后期代码维护
    /// </summary>
    public class AdapterLucene:Lucene,ISqlHelper
    {
        /// <summary>
        /// sql接口需要增删改查接口,但全表索引只有增、删、查接口,我就做一个适配类来处理不匹配
        /// </summary>
        public void Update()
        {
            base.Delete();
            base.Add();
        }
    }

 

适配者模式

原文:http://www.cnblogs.com/zhuyapeng/p/7073783.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!