日本国产亚洲-日本国产一区-日本国产一区二区三区-日本韩国欧美一区-日本韩国欧美在线-日本韩国欧美在线观看

當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

完成Prototype設(shè)計模式

完成Prototype設(shè)計模式

更新時間:2022-04-27 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

實現(xiàn)Prototype設(shè)計模式

Implementing the Prototype design Pattern



當(dāng)我建立一個類的實例很復(fù)雜時,我們可以使用Prototype模式。與其建立很多類的實例,還不如進(jìn)行適當(dāng)?shù)男薷暮螅褂米畛醯膶嵗母北尽J褂肞rototype模式,可以通過克隆一個原型,減少子類的數(shù)量。Prototype模式可以減少類的實例的數(shù)量。

在這個模式中,通過克隆來創(chuàng)建對象。我們有時創(chuàng)建很多的子類,除了通過很多的子類來創(chuàng)建不同的對象,我們還可以只需要唯一的一個子類,這個子類保持對每個對象基類的引用,并通過這個子類創(chuàng)建對象。通過向子類的構(gòu)造函數(shù)傳遞參數(shù)并克隆對象。每個對象都實現(xiàn)clone方法,所以可以被克隆。我們可以使用Prototype模式,通過克隆原型來減少子類的數(shù)量。

克隆可以通過實現(xiàn)Icloneable接口來實現(xiàn)。Icloneable接口中唯一的方法是Clone,并返回一個新的類的實例。

ICloneable.Clone method signature
[VisualBasic] Function Clone() As Object
[C#] object Clone();




我們必須了解Clone()方法只是一種淺表復(fù)制(Shallow copy),而不是深層復(fù)制(Deep copy)。所以它只是返回一個引用,而不象深層復(fù)制(Deep copy)那樣創(chuàng)建一個復(fù)制的實例。我們可以通過使用Iserializable接口來實現(xiàn)深層復(fù)制(Deep copy)。

另一個缺點就是原型的每個子類必須實現(xiàn)Clone()方法,有時候,增加clone方法是很困難的。

在這個例子中,我建立了EmpData類,并且實現(xiàn)了Icloneable接口和Iserializable接口。Icloneable接口需要實現(xiàn)Clone方法,使得類可以被復(fù)制。Iserializable接口為了實現(xiàn)對EmpData類的深層復(fù)制(Deep copy)。使用的方法為:將EmpData對象序列化為一個文件,也可以將這個文件反序列化為一個EmpData對象。

EmpData類包含兩個方法:GetEmpData和ChangeEmpData。這兩個方法被用來以一個字符串(string)的形式獲取EmpData對象、更改EmpData類。每個方法都可以被調(diào)用,來檢驗淺表復(fù)制(Shallow copy)和深層復(fù)制(Deep copy)的不同。淺表復(fù)制(Shallow copy)時,如果EmpData類改變時,這個變化也會同時出現(xiàn)在EmpData的克隆對象中;而在深層復(fù)制(Deep copy),如果EmpData對象發(fā)生改變時,這個變化不會出現(xiàn)在EmpData的克隆對象中。

EmpData類的構(gòu)造函數(shù)讀取XML文件并創(chuàng)建Emp對象。

XML 文件




VB.Net 實現(xiàn)



Imports System.Xml

Imports System.IO

Imports System.Collections

Imports System.Runtime.Serialization

Imports System.Runtime.Serialization.Formatters.Binary

<Serializable()> Public Class CEmpData

Implements ICloneable, ISerializable

Private ArrEmp As ArrayList

Public Sub New()

Dim xmldoc As New XmlDocument

Dim node As XmlNode

Dim objEmp As CEmp

ArrEmp = New ArrayList

xmldoc.Load("empdata.xml")

For Each node In xmldoc.DocumentElement.ChildNodes

objEmp = New CEmp

objEmp.FName = node.SelectSingleNode("firstname").InnerText

objEmp.LName = node.SelectSingleNode("lastname").InnerText

ArrEmp.Add(objEmp)

Next

End Sub

Public Sub New(ByVal info As SerializationInfo, ByVal context As StreamingContext)

Dim intIndex As Integer

Dim intCount As Integer

Dim objEmp As CEmp

ArrEmp = New ArrayList

intCount = CInt(info.GetValue("emp_count", GetType(String)))

For intIndex = 0 To intCount - 1

objEmp = New CEmp(info, context, intIndex)

ArrEmp.Add(objEmp)

Next

End Sub

Public Function Clone() As Object Implements ICloneable.Clone

Try

Return Me

Catch ex As Exception

MsgBox(ex.ToString)

End Try

End Function

Public Function Clone(ByVal Deep As Boolean) As Object

Try

If Deep Then

Return CreateDeepCopy()

Else

Return Clone()

End If

Catch ex As Exception

MsgBox(ex.ToString)

End Try

End Function

Private Function CreateDeepCopy() As CEmpData

Dim objEmpCopy As CEmpData

Dim objStream As Stream

Dim objBinFormatter As New BinaryFormatter

Try

objStream = File.Open("Empdata.bin", FileMode.Create)

objBinFormatter.Serialize(objStream, Me)

objStream.Close()

objStream = File.Open("Empdata.bin", FileMode.Open)

objEmpCopy = CType(objBinFormatter.Deserialize(objStream), CEmpData)

objStream.Close()

CreateDeepCopy = objEmpCopy

Catch ex As Exception

MsgBox(ex.ToString)

End Try

End Function

Public Sub GetObjectData(ByVal info As System.Runtime.Serialization.SerializationInfo, ByVal context As System.Runtime.Serialization.StreamingContext) Implements System.Runtime.Serialization.ISerializable.GetObjectData

Dim intIndex As Integer

Dim objEmp As CEmp

info.AddValue("emp_count", ArrEmp.Count)

For intIndex = 0 To ArrEmp.Count - 1

objEmp = ArrEmp(intIndex)

objEmp.GetObjectData(info, context, intIndex)

Next

End Sub

Public Function GetEmpData() As String

Dim intCount As Integer

Dim strEmpData As String

For intCount = 0 To ArrEmp.Count - 1

strEmpData = strEmpData & CType(ArrEmp(intCount), CEmp).FName & Chr(9) & CType(ArrEmp(intCount), CEmp).LName & Chr(13)

Next

GetEmpData = strEmpData

End Function

Public Sub ChangeEmpData()

Dim objEmp As CEmp

For Each objEmp In ArrEmp

objEmp.FName = "FirstName"

objEmp.LName = "LastName"

Next

End Sub

End Class

Public Class CEmp

Private mstrFName As String

Private mstrLName As String

Public Property FName() As String

Get

FName = mstrFName

End Get

Set(ByVal Value As String)

mstrFName = Value

End Set

End Property

Public Property LName() As String

Get

LName = mstrLName

End Get

Set(ByVal Value As String)

mstrLName = Value

End Set

End Property

Public Sub New()

End Sub

Public Sub New(ByVal info As SerializationInfo, ByVal context As StreamingContext, ByVal intIndex As Integer)

mstrFName = CStr(info.GetValue("emp_fname" & intIndex, GetType(String)))

mstrLName = CStr(info.GetValue("emp_lname" & intIndex, GetType(String)))

End Sub

Public Sub GetObjectData(ByVal info As SerializationInfo, ByVal context As StreamingContext, ByVal intIndex As Long)

info.AddValue("emp_fname" & intIndex, mstrFName)

info.AddValue("emp_lname" & intIndex, mstrLName)

End Sub

End Class

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

主站蜘蛛池模板: 免费人成黄页网站在线观看 | 国产亚洲精品久久久久久牛牛 | 伊人天天 | 成年人视频在线免费看 | 日韩在线视频免费 | 在线调教 | 五月天久久综合 | 欧美毛片在线观看 | 小明永久成人一区二区 | 蜜桃91丨九色丨蝌蚪 | 国产高清一区二区三区视频 | 欧美日韩在线观看一区二区 | 亚洲欧洲精品视频在线观看 | 亚洲欧美成人影院 | 91福利刘玥国产在线观看 | 伊人久久综在合线亚洲91 | 91精品国产一区二区三区四区 | 手机免费在线视频 | 精品精品 | 亚洲视频在线观看不卡 | 亚洲欧洲自拍 | 免费视频精品一区二区三区 | 国产成人亚洲精品无广告 | 亚洲国产成人精品不卡青青草原 | 免费国产在线观看 | a在线观看欧美在线观看 | 亚洲 欧美 卡通 在线 另类 | 福利视频一区二区思瑞 | 欧美激情五月 | 欧美成人性色生活片免费在线观看 | 免费公开在线视频 | 在线小视频国产 | 国产欧美日韩另类 | 免费看小视频 | 久久国产精品佐山爱 | 国产欧美在线观看 | 亚洲欧美中文字幕在线网站 | 99在线国产视频 | 午夜网站在线观看免费网址免费 | 久久精品视频免费 | 欧美一级高清在线观看 |