05 设计模式 原型设计模式
时间:2022-07-22
本文章向大家介绍05 设计模式 原型设计模式,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
原型设计模式
原型设计模式:顾名思义,通过一个原型来建立对象。因为有些对象过于庞大,通过new
关键字创立十分消耗资源,故采用原型设计模式,可以理解为克隆
在Java中原型设计模式主要靠
clone()
方法进行
进行clone
需要注意的点:
- 类本身需要实现
Cloneable
接口 - 如果其中有对象就需要覆写
clone()
方法,否则就会出现改一个,全部都被改的情况。
代码如下:
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
public class Video implements Cloneable{
String name;
Date date;
/*==================以下为重点=========================*/
@Override
protected Object clone() throws CloneNotSupportedException {
Object obj = super.clone();
Video video = (Video)obj;
video.date = (Date) this.getDate().clone();
return video;
}
}
测试方法:
public static void main(String[] args) throws CloneNotSupportedException {
Date date = new Date();
Video video1 = new Video("我的视频", date);
Video video2 = (Video) video1.clone();
System.out.println(video1);
System.out.println(video2);
date.setTime(1868421597);
System.out.println(video1);
System.out.println(video2);
}
没有覆写clone方法时的结果
Video{name='我的视频', date=Fri Jun 19 16:41:47 CST 2020} Video{name='我的视频', date=Fri Jun 19 16:41:47 CST 2020} Video{name='我的视频', date=Thu Jan 22 23:00:21 CST 1970} Video{name='我的视频', date=Thu Jan 22 23:00:21 CST 1970}
会发现,本来并没有想要改date属性,值却被修改了。
这是因为对象video1中保存的是date对象的地址,修改的是date对象本身。而这两个对象都指向一个地址,故都会发生改变
覆写后的结果:
Video{name='我的视频', date=Fri Jun 19 16:43:32 CST 2020} Video{name='我的视频', date=Fri Jun 19 16:43:32 CST 2020} Video{name='我的视频', date=Thu Jan 22 23:00:21 CST 1970} Video{name='我的视频', date=Fri Jun 19 16:43:32 CST 2020}
由此发现正常了!
一般在使用时,原型设计模式并不会单独使用,会与工厂模式相结合,更加高效地创建对象
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法