摘要:原型模型通過拷貝創建對象,也可歸結為的創建型的設計模式。原型模式的示例實現接口調用父類的方法進行拷貝。實現深拷貝這種方式是先分配內存大小,然后通過內存塊的復制操作來實現賦值的,效率可能會比出來一個對象的效率高點。
原型模型通過拷貝創建對象,也可歸結為的創建型的設計模式。
原型模式的示例:
public class Prototype { public static void main(String[] args) { Field field = new Field("code"); System.out.println("field=[" + field + "]"); field.setCode("codedes"); Field fieldCopy = field.clone(); System.out.println("fieldCopy=[" + fieldCopy + "]"); } } class Field implements Cloneable { private String code; public Field(String code) { this.code = code; } public void setCode(String code) { this.code = code; } @Override public String toString() { return "Field{" + "code="" + code + """ + "}"; } public Field clone() { Field field = null; try { field = (Field) super.clone(); } catch (CloneNotSupportedException e) { throw new RuntimeException(e); } return field; } }
1、實現Cloneable接口
2、調用object父類的clone方法進行拷貝。這里的拷貝是淺拷貝。
實現深拷貝:
public class Prototype { public static void main(String[] args) { Field field = new Field("code", new Type("string")); System.out.println("field=[" + field + "]"); field.setCode("codedes"); Field fieldCopy = field.clone(); System.out.println("fieldCopy=[" + fieldCopy + "]"); } } class Type implements Cloneable { private String typeName; public Type(String typeName) { this.typeName = typeName; } public Type clone(){ Type type = null; try { type = (Type) super.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } return type; } } class Field implements Cloneable { private String code; private Type type; public Field(String code, Type type) { this.code = code; this.type = type; } public void setCode(String code) { this.code = code; } @Override public String toString() { return "Field{" + "code="" + code + """ + ", type=" + type + "}"; } public Field clone() { Field field = null; try { field = (Field) super.clone(); field.type = type.clone(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } return field; } }
clone這種方式是先分配內存大小,然后通過內存塊的復制操作來實現賦值的,效率可能會比new出來一個對象的效率高點。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/66707.html
摘要:首先,需要來理清一些基礎的計算機編程概念編程哲學與設計模式計算機編程理念源自于對現實抽象的哲學思考,面向對象編程是其一種思維方式,與它并駕齊驅的是另外兩種思路過程式和函數式編程。 JavaScript 中的原型機制一直以來都被眾多開發者(包括本人)低估甚至忽視了,這是因為絕大多數人沒有想要深刻理解這個機制的內涵,以及越來越多的開發者缺乏計算機編程相關的基礎知識。對于這樣的開發者來說 J...
摘要:于是就有了構造函數和原型模式混合模式組合使用構造函數模式和原型模式創建自定義類型最常見的方式,就是組合模式。 創建對象 JS有六種數據數據類型,其中五種屬于基本數據類型:Null、Boolean、undefined、String、Number。而其它值都是對象。數組是對象,函數是對象,正則表達式是對象。對象也是對象。 來看一下對象的定義: 無序屬性的集合,其屬性可以包含基本值、對象、或...
摘要:創建構造函數后,其原型對象默認只會取得屬性至于其他的方法都是從繼承來的。上圖展示了構造函數的原型對象和現有的兩個實例之間的關系。所有原生的引用類型都在其構造函數的原型上定義了方法。 第6章我一共寫了3篇總結,下面是相關鏈接:讀《javaScript高級程序設計-第6章》之理解對象讀《javaScript高級程序設計-第6章》之繼承 工廠模式 所謂的工廠模式就是,把創建具體對象的過程抽象...
摘要:目錄導語理解對象和面向對象的程序設計創建對象的方式的繼承機制原型對象原型鏈與原型對象相關的方法小結導語前面的系列文章,基本把的核心知識點的基本語法標準庫等章節講解完本章開始進入核心知識點的高級部分面向對象的程序設計,這一部分的內容將會對對象 目錄 導語 1.理解對象和面向對象的程序設計 2.創建對象的方式 3.JavaScript的繼承機制 3.1 原型對象 3.2 原型鏈 3.3 與...
閱讀 3563·2021-11-22 15:11
閱讀 4643·2021-11-18 13:15
閱讀 2710·2019-08-29 14:08
閱讀 3583·2019-08-26 13:49
閱讀 3100·2019-08-26 12:17
閱讀 3295·2019-08-26 11:54
閱讀 3119·2019-08-26 10:58
閱讀 2039·2019-08-26 10:21