天天看点

乐在其中设计模式(C#) - 适配器模式(Adapter Pattern)

乐在其中设计模式(C#) - 适配器模式(Adapter Pattern)

介绍

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

示例

有一个Message实体类,某个类对它的操作有Insert()和Get()方法。现在需要把这个类转到另一个接口,分别对应Add()和Select()方法。

MessageModel

using System; 

using System.Collections.Generic; 

using System.Text; 

namespace Pattern.Adapter 

        /// <summary> 

        /// Message实体类 

        /// </summary> 

        public class MessageModel 

        { 

                /// <summary> 

                /// 构造函数 

                /// </summary> 

                /// <param name="msg">Message内容</param> 

                /// <param name="pt">Message发布时间</param> 

                public MessageModel(string msg, DateTime pt) 

                { 

                        this._message = msg; 

                        this._publishTime = pt; 

                } 

                private string _message; 

                /// Message内容 

                public string Message 

                        get { return _message; } 

                        set { _message = value; } 

                private DateTime _publishTime; 

                /// Message发布时间 

                public DateTime PublishTime 

                        get { return _publishTime; } 

                        set { _publishTime = value; } 

        } 

}

SqlMessage

        /// 源(Adaptee)角色 

        /// Sql方式操作Message 

        public class SqlMessage 

                /// 获取Message 

                /// <returns></returns> 

                public List<MessageModel> Get() 

                        List<MessageModel> l = new List<MessageModel>(); 

                        l.Add(new MessageModel("SQL方式获取Message", DateTime.Now)); 

                        return l; 

                /// 插入Message 

                /// <param name="mm">Message实体对象</param> 

                public bool Insert(MessageModel mm) 

                        // 代码略 

                        return true; 

IMessage

        /// 目标(Target)角色 

        /// 操作Message的接口 

        public interface IMessage 

                List<MessageModel> Select(); 

                bool Add(MessageModel mm); 

Message

        /// 适配器(Adapter)角色 

        /// 类适配器 

        /// 把源适配到这个类 

        public class Message : SqlMessage, IMessage 

                public List<MessageModel> Select() 

                        return base.Get(); 

                public bool Add(MessageModel mm) 

                        return base.Insert(mm); 

Message2

        /// 对象适配器 

        public class Message2 : IMessage 

                private SqlMessage _sqlMessage; 

                public Message2() 

                        _sqlMessage = new SqlMessage(); 

                        return _sqlMessage.Get(); 

                        return _sqlMessage.Insert(mm); 

client

using System.Data; 

using System.Configuration; 

using System.Collections; 

using System.Web; 

using System.Web.Security; 

using System.Web.UI; 

using System.Web.UI.WebControls; 

using System.Web.UI.WebControls.WebParts; 

using System.Web.UI.HtmlControls; 

using Pattern.Adapter; 

public partial class Adapter : System.Web.UI.Page 

        protected void Page_Load(object sender, EventArgs e) 

                IMessage m; 

                m = new Message(); 

                Response.Write("类适配器方式<br />"); 

                Response.Write(m.Add(new MessageModel("插入", DateTime.Now))); 

                Response.Write("<br />"); 

                Response.Write(m.Select()[0].Message + " " + m.Select()[0].PublishTime.ToString()); 

                Response.Write("<br /><br />"); 

                m = new Message2(); 

                Response.Write("对象适配器方式<br />"); 

运行结果

类适配器方式

True

SQL方式获取Message 2007-4-8 20:59:29 

对象适配器方式

SQL方式获取Message 2007-4-8 20:59:29

参考

<a href="http://www.dofactory.com/Patterns/PatternAdapter.aspx" target="_blank">http://www.dofactory.com/Patterns/PatternAdapter.aspx</a>

OK

<a href="http://down.51cto.com/data/100859" target="_blank">[源码下载]</a>

     本文转自webabcd 51CTO博客,原文链接:http://blog.51cto.com/webabcd/344517,如需转载请自行联系原作者