早会,你拿着电脑在会议室里新建了一个记事本,用着搜狗输入法,疯狂的记录着你们部门老大的各种会议纪要。
时间很快,等散会的时候已经中午了,此时阿良才着急忙慌的赶到。看着他手足无措的样子,你淡定的对他说,不要急,会议内容都被你记录下来了,等会拷贝给他一份就好了。听完你的话,他忐忑的心才慢慢放下。
我们日常生活使用电脑时,经常会用到的一个操作,就是复制粘贴,即 Ctrl+C和Ctrl+V。但是编程中,我们创建了一个对象,想在使用时拷贝出来一份该怎么办呢。这就是今天想提到的设计模式,原型模式。
以目标对象为原型实例,通过复制的方式创建新对象。
其实换成人话就是:在内存里复制一个内容一模一样的新的对象。
创建对象时,在构造函数中会进行大量的资源消耗操作。举几个比较夸张的例子:比如说可能进行网络申请或者说拷贝个几百m的数据到本地,再或者说要检查下本地内存卡或者电脑硬盘上有多少个文件夹。这些都是很耗时的计算,但是这些都是在创建该对象之前的准备工作(举例而已,可能有点夸张)。此时可以使用原型模式,直接在内存中复制一个一模一样的对象。
1. 继承实现Clone接口
2. 对象内部的基本数据类型变量,会直接拷贝。
3. 引用数据类型,可以根据需求。自行实现深拷贝或者浅拷贝(默认即浅拷贝,类比成快捷方式)
/** * @author:TianLong * @date:2022/10/18 19:47 * @detail:原型模式 具体实现类 */ class Book implements Cloneable{ public ArrayList<String> articles = new ArrayList<>(); public String author = ""; public int price = 0; public String publishers = ""; public Book(ArrayList<String> articles, String author, int price, String publishers) { this.articles = articles; this.author = author; this.price = price; this.publishers = publishers; } @Override public Book clone() { Book book = null; try { book = (Book) super.clone(); // 引用数据类型,需实现深拷贝 book.articles = (ArrayList<String>) this.articles.clone(); } catch (CloneNotSupportedException e) { throw new RuntimeException(e); } return book; } @Override public String toString() { return "Book{" + "articles=" + articles + ", author='" + author + '\'' + ", price=" + price + ", publishers='" + publishers + '\'' + '}'; } }
/** * @author:TianLong * @date:2022/10/18 19:52 * @detail:客户端 */ class Client { public static void main(String[] args) { ArrayList<String>arrayList=new ArrayList<>(); arrayList.add("丑小鸭"); arrayList.add("白雪公主"); arrayList.add("小红帽"); Book book = new Book(arrayList,"安徒生",20,"人民出版社"); Book cloneBook = book.clone(); // 引用数据类型 book.articles.add("大闹天宫"); // 数据输出 System.out.println(book.toString()); System.out.println(cloneBook.toString()); } }
原型模式就像是在Ctrl+C和Ctrl+V一样。可以帮我们快速的在内存中创建出一个对象。唯一要注意的是,拷贝出来的数据是 ”快捷方式“ ,还是一个 ”单独的文件“