天天看點

樂在其中設計模式(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,如需轉載請自行聯系原作者