2016.12.31 学习日记-适配器模式

2016的最后一天,回望过去,展望未来。这一年发生了太多太多,迷茫里小半年,也庆幸自己在这一年的尾巴找到了方向,重新上路。2017,只希望自己能够好好的学习,体会编程的快乐。祝所有的朋友,新年快乐!

最后一天学习的是适配器模式。


适配器模式(Adapter Pattern)

定义:将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。


模式中的角色

目标接口(Target):客户所期待的接口。目标可以是具体的或抽象的类,也可以是接口。

需要适配的类(Adaptee):需要适配的类或适配者类。

适配器(Adapter):通过包装一个需要适配的对象,把原接口转换成目标接口。


类图:



实例代码(大话设计模式  篮球翻译适配器):

Player.cs

abstract class Player
    {
        protected string name;
        public Player(string name)
        {
            this.name = name;
        }

        public abstract void Attack();
        public abstract void Defence();

    }

Guards.cs

class Guards : Player
    {
        public Guards(string name)
            : base(name)
        {

        }
        public override void Attack()
        {
            Console.WriteLine("后卫{0}进攻", name);
        }

        public override void Defence()
        {
            Console.WriteLine("后卫{0}防守", name);
        }
    }

Forwards.cs

class Forwards : Player
    {
        public Forwards(string name)
            : base(name)
        {

        }
        public override void Attack()
        {
            Console.WriteLine("前锋{0}进攻", name);
        }

        public override void Defence()
        {
            Console.WriteLine("前锋{0}防守", name);
        }
    }

Translator.cs(适配器)

class Translator : Player
    {
        private ForeignCenter wjzf = new ForeignCenter();

        public Translator(string name)
            : base(name)
        {
            wjzf.Name = name;
        }

        public override void Attack()
        {
            wjzf.进攻();
        }

        public override void Defence()
        {
            wjzf.防守();   
        }

    }

ForeignCenter.cs(需要适配的类)

class ForeignCenter
    {
        private string name;

        public string Name
        {
            get { return name; }
            set { name = value; }
        }

        public void 进攻()
        {
            Console.WriteLine("外籍中锋{0}进攻", name);
        }

        public void 防守()
        {
            Console.WriteLine("外籍中锋{0}防守", name);
        }
    }

Program.cs

class Program
    {
        static void Main(string[] args)
        {
            Player Tmac = new Guards("麦迪");
            Tmac.Attack();

            Player Ba = new Forwards("巴蒂尔");
            Ba.Defence();

            Player Yao = new Translator("姚明");
            Yao.Attack();
            Yao.Defence();

            Console.ReadKey();
        }
    }

优点

通过适配器,客户端可以调用同一接口,因而对客户端来说是透明的。这样做更简单、更直接、更紧凑。

复用了现存的类,解决了现存类和复用环境要求不一致的问题。

将目标类和适配者类解耦,通过引入一个适配器类重用现有的适配者类,而无需修改原有代码。

一个对象适配器可以把多个不同的适配者类适配到同一个目标,也就是说,同一个适配器可以把适配者类和它的子类都适配到目标接口。

 缺点

对于对象适配器来说,更换适配器的实现过程比较复杂。

适用场景

系统需要使用现有的类,而这些类的接口不符合系统的接口。

想要建立一个可以重用的类,用于与一些彼此之间没有太大关联的一些类,包括一些可能在将来引进的类一起工作。

两个类所做的事情相同或相似,但是具有不同接口的时候。

旧的系统开发的类已经实现了一些功能,但是客户端却只能以另外接口的形式访问,但我们不希望手动更改原有类的时候。

使用第三方组件,组件接口定义和自己定义的不同,不希望修改自己的接口,但是要使用第三方组件接口的功能。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值