【设计模式-享元模式】
时间:2022-07-24
本文章向大家介绍【设计模式-享元模式】,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
【导读】程序设计有时会面临需要创建大量相同对象或相似对象,创建大量的对象会耗费大量的内存,此时就需要一个创建之后可以重复使用的设计,这就是享元模式。
一、定义
提供了减少对象的数量从而改善应用所需的对象结构的方式。应用于系统底层的开发,以便解决系统的性能问题。适用于缓存场景。
二、实例
比如在开发中,如果需要用到具体某种功能的组件,我们不会首先想自己搞一个,而是会去搜索一下网上有没有相应的软件,如果有的话就直接拿过来用(平时搬砖也差不多),如果没有,就只能自己敲了。
组件:
public class Module {
private String moduleName;
public Module(String moduleName) {
this.moduleName = moduleName;
}
}
公共研发部:
public class CommonDevFactory {
1、维护一个Map缓存对象
public static final Map<String,Module> MODULE_MAP
= new HashMap<String, Module>();
/**
* 获取组件
* @return
*/
public static Module getModule(String moduleName) {
2、看一下缓存中有没有相应的组件
Module module = MODULE_MAP.get(moduleName);
3、如果没有,全新开发
if (null == module) {
module = new Module(moduleName);
System.out.println("需要全新研发"+moduleName);
MODULE_MAP.put(moduleName,module);
} else {
4、如果有,直接拿来用
System.out.println(moduleName+"已有,直接使用,无需再次研发");
}
return module;
}
}
测试类:
public class Main {
//组件类型
private static String[] modules = new String[]{"RabbitMQ","Redis","Double","UI"};
public static void main(String[] args) {
for (int i = 0; i < 10; i++) {
String module = modules[(int)(Math.random()*modules.length)];
CommonDevFactory.getModule(module);
}
}
}
运行结果:
接下来看一下类图(比较简单):
就相当于创建了一次就直接存起来,等需要用到的时候直接拿来用就行了,不用再耗时耗精力去重新创建一个。
三、源码实例
(1)JVM里面的字符串常量池
public native String intern();
(2)Integer的valueOf方法在-128~127之间的数字是直接用一个数组缓存起来的。
public static Integer valueOf(int i) {
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
(3)数据库连接池,线程池等。
- 执行git push出现"Everything up-to-date"
- linux下EOF写法梳理
- 用AngularJS来实现异步数据的购物车功能设计
- span不如div的地方
- 分布式监控系统Zabbix--完整安装记录(7)-使用percona监控MySQL
- 10x Python开发者必读:本月Python文章TOP 10
- Linux下更换默认yum源为网易yum源的操作记录
- yum源使用的几个报错小总结
- JQuery笔记(一)
- Haproxy和Nginx负载均衡测试效果对比记录
- JQuery笔记(三) jquery的用途
- Heartbeat使用梳理
- JQuery笔记(二) animate支持的属性
- 腾讯叮当首次系统性展示AI能力 开放日展示实战型解决方案
- 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 数组属性和方法
- 基于Java swing开发的雷霆战机
- 浅谈双缓冲技术在游戏里面的应用【java】
- 拥抱 Vue 3 系列之 JSX 语法
- c#多态性 静态多态性函数重载 动态多态性 虚方法:
- 如何开发跨框架的组件
- ZooTeam 拍了拍你,来看看如何设计动态化表单
- C# 继承 基类和派生类基类的初始化C# 多重继承
- Go语言ORM-gorm学习笔记(一)
- Etcd+Prometheus+Grafana
- 梳理 6 项 webpack 的性能优化
- 第2章 Jenkins Server的安装部署方式
- 在MacOSX机器上设置JenkinsCI服务器
- springboot2配置文件定义${user.name}内容失效问题探究
- 重学Javascript之数据类型
- JPEG/Exif/TIFF格式解读(1):JEPG图片压缩与存储原理分析