Cache概念及组成结构
Cache,是 一种后关系型数据库。能并发访问同一数据的数据库技术。对于Cache概念及组成知识你了解多少?下面小编整理了Cache概念及组成结构,供大家参阅。
基本概念
在计算机存储系统的层次结构中,介于中央处理器和主存储器之间的高速小容量存储器。它和主存储器一起构成一级的存储器。高速缓冲存储器和主存储器之间信息的`调度和传送是由硬件自动进行的。
某些机器甚至有二级三级缓存,每级缓存比前一级缓存速度慢且容量大。
组成结构
高速缓冲存储器是存在于主存与CPU之间的一级存储器, 由静态存储芯片(SRAM)组成,容量比较小但速度比主存高得多, 接近于CPU的速度。
主要由三大部分组成:
Cache存储体:存放由主存调入的指令与数据块。
地址转换部件:建立目录表以实现主存地址到缓存地址的转换。
替换部件:在缓存已满时按一定策略进行数据块替换,并修改地址转换部件。
补充说明:Java 中常用缓存Cache机制的实现
缓存主要可分为二大类:
一、通过文件缓存,顾名思义文件缓存是指把数据存储在磁盘上,不管你是以XML格式,序列化文件DAT格式还是其它文件格式;
二、内存缓存,也就是实现一个类中静态Map,对这个Map进行常规的增删查.
代码如下 :
1. packagelhm.hcy.guge.frameset.cache;
2.
3. importjava.util.*;
4.
5. //Description:管理缓存
6.
7. //可扩展的功能:当chche到内存溢出时必须清除掉最早期的一些缓存对象,这就要求对每个缓存对象保存创建时间
8.
9. publicclassCacheManager{
10. privatestaticHashMapcacheMap=newHashMap();
11.
12. //单实例构造方法
13. privateCacheManager(){
14. super();
15. }
16. //获取布尔值的缓存
17. publicstaticbooleangetSimpleFlag(Stringkey){
18. try{
19. return(Boolean)cacheMap.get(key);
20. }catch(NullPointerExceptione){
21. returnfalse;
22. }
23. }
24. publicstaticlonggetServerStartdt(Stringkey){
25. try{
26. return(Long)cacheMap.get(key);
27. }catch(Exceptionex){
28. return0;
29. }
30. }
31. //设置布尔值的缓存
32. publicsynchronizedstaticbooleansetSimpleFlag(Stringkey,booleanflag){
33. if(flag&&getSimpleFlag(key)){//假如为真不允许被覆盖
34. returnfalse;
35. }else{
36. cacheMap.put(key,flag);
37. returntrue;
38. }
39. }
40. publicsynchronizedstaticbooleansetSimpleFlag(Stringkey,longserverbegrundt){
41. if(cacheMap.get(key)==null){
42. cacheMap.put(key,serverbegrundt);
43. returntrue;
44. }else{
45. returnfalse;
46. }
47. }
48.
49.
50. //得到缓存。同步静态方法
51. privatesynchronizedstaticCachegetCache(Stringkey){
52. return(Cache)cacheMap.get(key);
53. }
54.
55. //判断是否存在一个缓存
56. privatesynchronizedstaticbooleanhasCache(Stringkey){
57. returncacheMap.containsKey(key);
58. }
59.
60. //清除所有缓存
61. publicsynchronizedstaticvoidclearAll(){
62. cacheMap.clear();
63. }
64.
65. //清除某一类特定缓存,通过遍历HASHMAP下的所有对象,来判断它的KEY与传入的TYPE是否匹配
66. publicsynchronizedstaticvoidclearAll(Stringtype){
67. Iteratori=cacheMap.entrySet().iterator();
68. Stringkey;
69. ArrayListarr=newArrayList();
70. try{
71. while(i.hasNext()){
72. java.util.Map.Entryentry=(java.util.Map.Entry)i.next();
73. key=(String)entry.getKey();
74. if(key.startsWith(type)){//如果匹配则删除掉
75. arr.add(key);
76. }
77. }
78. for(intk=0;k<arr.size();k++){
79. clearOnly(arr.get(k));
80. }
81. }catch(Exceptionex){
82. ex.printStackTrace();
83. }
84. }
85.
86. //清除指定的缓存
87. publicsynchronizedstaticvoidclearOnly(Stringkey){
88. cacheMap.remove(key);
89. }
90.
91. //载入缓存
92. publicsynchronizedstaticvoidputCache(Stringkey,Cacheobj){
93. cacheMap.put(key,obj);
94. }
95.
96. //获取缓存信息
97. publicstaticCachegetCacheInfo(Stringkey){
98.
99. if(hasCache(key)){
100. Cachecache=getCache(key);