博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
浅谈java缓存
阅读量:6186 次
发布时间:2019-06-21

本文共 1134 字,大约阅读时间需要 3 分钟。

 java中要用到缓存的地方很多,首当其冲的就是持久层缓存,针对持久层谈一下: 

要实现java缓存有很多种方式,最简单的无非就是static HashMap,这个显然是基于内存缓存,一个map就可以搞定引用对象的缓存,最简单也最不实用,首要的问题就是保存对象的有效性以及周期无法控制,这样很容易就导致内存急剧上升,周期无法控制可以采用SoftReference,WeakReference,PhantomReference这三种对象来执行(看了Ibatis的缓存机制才发现JDK居然还提供了PhantomReference这玩意儿,得恶补基础啊),这三种都是弱引用,区别在于强度不同,至于弱引用概念个人理解就是对象的生命周期与JVM挂钩,JVM内存不够了就回收,这样能很好的控制OutOfMemoryError 异常。 
(推荐文章:http://www.ibm.com/developerworks/cn/java/j-jtp11225/>  
    以上就是内存级别的缓存,但是很多情况下是满足不了企业应用的,大数据量的缓存肯定还是要保存到文件,这个时候光用JDK来实现就比较复杂了,这里当然要用到第三方开源框架来实现了,常用的有Oscache,Ehcache,Jcache,Jbosscache等等很多,推荐还是Ehcache与Oscache,hibernate采用了Ehcache做为其缓存机制默认实现,Oscache没深入研究,但是Ibatis推荐的缓存为这个。 
为什么要缓存,无非就是节省访问时间已经大并发量带来的访问上资源的消耗,这个资源有软资源和硬资源,做java的几乎每天都在有意识或者无意识的跟缓存打交道,最常见的缓存,Connection Pool,还有IOC其实也算一个。 
     缓存用的好能提高性能,用的不好反而会急剧的降低产品的性能,就拿hibernate来说,hibernate性能肯定不如jdbc,但是缓存用的好的话增删改查的性能相差无几,hibernate缓存最核心的部分个人觉得在于对象的有效性,缓存的命中率越高意味着性能越高,命中率跟缓存对象的有效性息息相关,如何保证对象有效这个很难,也很有搞头,如果缓存中对象有效性很差,其性能甚至会低于不用缓存,因为缓存本身就会耗性能跟资源,缓存的对象很多都很快失效了无疑得不偿失,还有缓存的深度也有讲究,这个深度是指从页面到数据库,显然是页面缓存的性能最好,因为调用页面缓存消耗的资源最少,当然现实中是不可能有太多页面缓存的。 
     个人觉得缓存是把双刃剑,一定要根据缓存的特征和业务场景来选择使用才能发挥其最大优势。

转载于:https://www.cnblogs.com/xtdxs/p/6575897.html

你可能感兴趣的文章
【Android】APT(编译时生成代码)
查看>>
直播多人连麦技术简介
查看>>
《自动化办公》两秒完成250页豆瓣电影PPT
查看>>
作为前端,你不得不知道的搜索引擎优化
查看>>
编译deno,deno结构解析
查看>>
推动快递保价大众化,顺丰、京东、通达系谁更彻底?
查看>>
Qtum量子链研究院:Qtum Plasma MVP 技术详解
查看>>
iOS规范
查看>>
关于安卓手机访问一些网站或者Fiori应用弹出安装证书的提示
查看>>
VR全景图片浏览实现
查看>>
redux的combineReducers源码,中文翻译
查看>>
Weex系列(7) ——踩坑填坑的总总
查看>>
用户案例 - 3Cs
查看>>
PAT A1023 sort cmp字典序比较
查看>>
Kafka 集群 Golang 应用实例
查看>>
Stream流与Lambda表达式(六) SpliteratorDetail
查看>>
并查集算法 - Algorithms, Part I, week 1 UNION-FIND
查看>>
基于 CODING 的 Spring Boot 持续集成项目
查看>>
Vue 中组件使用中的细节点
查看>>
视频转mp4格式转换器如何把其他格式的视频转换成mp4格式
查看>>