缓冲&缓存&对象池概念的理解
一)、缓冲
作用:缓解程序上下层之间的性能差异。
1)、当上层组件的性能优于下层组件时加入缓冲机制可以减少上层组件对下
层组件的等待时间。
2)、上层组件不需要等待下层组件接收全部数据,即可返回操作,加快了上
层组件的处理速度。
缓冲的应用:
JDK的I/O组件提供了缓冲功能。
例:当对文件进行写操作时需要从内存中读取数据写入到硬盘,此时,文件从
内存中的读取速度比写入硬盘的速度快,此时就出现了上层组件的性能优
于下层组件的情况,此时可以加入缓冲机制BufferInputStream()先将数据
写入缓冲区,再将数据写道硬盘中。
二)、缓存
定义:是一块为提高系统性能的内存空间。
作用:暂存数据处理结果,并提供下次访问使用。
应用场景:
数据处理或数据获取可能会非常耗时,当数据的请求量很大时,频繁的数据处
理会耗尽cpu资源。
简单缓存的实现:直接使用HashMap
弊端:
1)、不知道应该何时清理无效数据。
2)、如何防止数据过多导致内存溢出。
基于java的缓存框架:
EHCache: Hibernate默认的数据缓存解决方案。
OSCache: 由OpenSymphony设计的,可以缓存任何对象,甚至是缓存
部分JSP页面,或者Http请求。JBossCache: 由JBoss开发,可用于JBoss集群间数据共享的缓存框架。
缓存的应用:建议在频繁使用且重负载的的函数中加入缓存,以提高它在频繁调用的性能,可以根据传入的参数构建key。
基于动态代理的缓存解决方案:
1).在方法中加入缓存的弊端:缓存组件和业务层代码紧密耦合,依赖性强。
- . 使用动态代理实现缓存好处:在业务层,无需关注对缓存的操作,代码被完全独立并隔离,对一个新的函数方法,加入缓存不会影响原有方法的实现。
三)、对象复用池
对象池化:若一个类被频繁请求使用,则将这个类的实例保存在一个池中,使用时,直接从池中获取。
对象池可以是一个数组、链表或任何集合类。
对象池的应用:
1)、线程池:
2)、数据库连接池
广泛使用的数据连接池组件:
1)、c3p0连接池 2)、ProXool连接池
c3p0连接池的实现:
Connection con = pool.getConnection()
con的类类型:com.mchange.V2.c3p0.impl.NewProxyConnection
1)、通过数据连接池对象调用getConnection获取数据库连接对象,此时得到的 Connection对象时一个NewProxyConnection代理对象.
2)、实际的数据库连接对象是在Connection中的一个内部类对象来连接获取的
Object re = f.get()
re的类类型:com.msql.jdbc.JDBC4Connection
Field f = con.getClass().getDeclaredFiled("inner") //通过反射获取内部类对象
Object re = f.get() //获取实际的数据库连接
结论:当调用con.close()并没有真正的关闭数据库的连接,而是将数据库连接放入数据库连接池保存,当用户第二次调用getConnection时从连接池中获取 连接对象。
四)、Jakarta commons Pool对象池组件
Jakarta commons Poll对象池组件由Apache提供。
定义了两个接口:
ObjectPool(对象池接口)
public interface ObjectPool{
//从对象池中取一个对象
T boorowObject();
//将对象返回给对象池
void returnObject(T boorowed);
}
PoolableObjectFactory : 对象池管理工厂
public interface PoolableObjectFactory{
//创建对象,若对象池没有对象,在borrowObject()时会自动调用
T MakeObject();
//在创建对象前使用,激活对象
void activateObject(T Object);
//在对象返回对象池时使用
void passivateObject(T Object);
//判断对象是否可用
void validateObject(T Object);
//pool.close()对象从对象池中销毁使用
void destoryObject(T Object);
}
内置定义了3个对象池
1)、StackObjectPool
使用java.util.Stack来保存对象,可以指定初始化大小,当空间不够时,可以自
动增长,无可用对象时,可以自动创建新对象。
2)、GenericObjectPool
通用对象池,可以设定对象池的容量,可设定无可用对象时,对象池的表现行
为(等待或创建新实例),可以设置对象有效性检查
3)、softReferenceObjectPool
使用ArrayList保存对象,不保存对象的强引用,只保存对象的弱引用,对对象
数量没有限制,当没有对象时会自动创建对象,当内存紧张时,Jvm自动回收
具有弱引用对象。
缓冲&缓存&对象池概念的理解的更多相关文章
- javascript设计模式学习之四——单例模式,缓存与对象池
单例模式的定义:确保一个实例,并提供全局访问. 惰性单例的定义:只在需要的时候才创建对象. 在开发中,有些对象往往只需要一个,比如线程池.全局缓存.浏览器中的window对象等. java中的单例 关 ...
- 抓到 Netty 一个隐藏很深的内存泄露 Bug | 详解 Recycler 对象池的精妙设计与实现
欢迎关注公众号:bin的技术小屋,如果大家在看文章的时候发现图片加载不了,可以到公众号查看原文 本系列Netty源码解析文章基于 4.1.56.Final版本 最近在 Review Netty 代码的 ...
- Netty轻量级对象池实现分析
什么是对象池技术?对象池应用在哪些地方? 对象池其实就是缓存一些对象从而避免大量创建同一个类型的对象,类似线程池的概念.对象池缓存了一些已经创建好的对象,避免需要时才创建对象,同时限制了实例的个数.池 ...
- Unity 游戏框架搭建 (十九) 简易对象池
在Unity中我们经常会用到对象池,使用对象池无非就是解决两个问题: 一是减少new时候寻址造成的消耗,该消耗的原因是内存碎片. 二是减少Object.Instantiate时内部进行序列化和反序列化 ...
- 大数据技术之_27_电商平台数据分析项目_02_预备知识 + Scala + Spark Core + Spark SQL + Spark Streaming + Java 对象池
第0章 预备知识0.1 Scala0.1.1 Scala 操作符0.1.2 拉链操作0.2 Spark Core0.2.1 Spark RDD 持久化0.2.2 Spark 共享变量0.3 Spark ...
- python tips:小整数对象池与字符串intern
本文为is同一性运算符的详细解释.is用于判断两个对象是否为同一个对象,具体来说是两个对象在内存中的位置是否相同. python为了提高效率,节省内存,在实现上大量使用了缓冲池技术和字符串intern ...
- 【JVM】Java 8 中的常量池、字符串池、包装类对象池
1 - 引言 2 - 常量池 2.1 你真的懂 Java的“字面量”和“常量”吗? 2.2 常量和静态/运行时常量池有什么关系?什么是常量池? 2.3 字节码下的常量池以及常量池的加载机制 2.4 是 ...
- 对象池与.net—从一个内存池实现说起
本来想写篇关于System.Collections.Immutable中提供的ImmutableList里一些实现细节来着,结果一时想不起来源码在哪里--为什么会变成这样呢--第一次有了想写分析的源码 ...
- common-pool2对象池(连接池)的介绍及使用
我们在服务器开发的过程中,往往会有一些对象,它的创建和初始化需要的时间比较长,比如数据库连接,网络IO,大数据对象等.在大量使用这些对象时,如果不采用一些技术优化,就会造成一些不可忽略的性能影响.一种 ...
随机推荐
- Linux面试题-8
1.Linux文件系统的文件都按其作用分门别类地放在相关的目录中,对于磁盘这种外部设备文件,一般应将其放在(C)目录中. A./bin B./etc C./dev D./lib 2.当使用mount进 ...
- 基于SignalR的服务端和客户端通讯处理
SignalR是一个.NET Core/.NET Framework的实时通讯的框架,一般应用在ASP.NET上,当然也可以应用在Winform上实现服务端和客户端的消息通讯,本篇随笔主要基于Sign ...
- ESP8266开发之旅 网络篇⑦ TCP Server & TCP Client
授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...
- 误删除 mySQL 用户解决办法
误删除用户解决办法 删除用户 删除用户 mysql> truncate mysql.user;Query OK, 0 rows affected (0.05 sec)mysql> sel ...
- postman的基本用法,请求,断言,环境变量
postman基本用法 Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件. 它提供功能强大的 Web API & HTTP 请求调试. 它能够发送任何类型的HTT ...
- Java 读取properties 配置文件的几种方式
基于ClassLoder读取配置文件 Properties properties = new Properties(); // 使用ClassLoader加载properties配置文件生成对应的输入 ...
- 在VMware下的Linux中的RAID5校验位算法下的磁盘管理
前景:1988年由加利福尼亚大学伯克利分校发表的文章首次提到并定义了RAID,当今CPU性能每年可提升30%-50%但硬盘仅提升7%,渐渐的已经成为计算机整体性能的瓶颈,并且为了避免硬盘的突然损坏导致 ...
- 命令行代理神器 proxychains
因为某些原因,我们需要在命令行下载一些国外的资源,这个时候如果使用 wget,curl,或者 aria2c 的时候,往往又没有速度.这个时候我们需要使用代理来进行加速. 我本地搭的有 ss,但 ss ...
- Go 程序的性能监控与分析 pprof
你有没有考虑过,你的goroutines是如何被go的runtime系统调度的?是否尝试理解过为什么在程序中增加了并发,但并没有给它带来更好的性能?go执行跟踪程序可以帮助回答这些疑问,还有其他和其有 ...
- NOI导刊集训感言
圆溜溜,尤其首先,集训的收获很大,远远比自学要来的快 其次,新知识点到时没怎么讲(A*,数论除外,倒是真的学会不少以前碰都不敢碰的定理呀,结论之类的东西),但是还是深深地感受到了集训的困难,七天的节奏 ...