Cache概念及組成結(jié)構(gòu)
Cache,是 一種后關(guān)系型數(shù)據(jù)庫(kù)。能并發(fā)訪問(wèn)同一數(shù)據(jù)的數(shù)據(jù)庫(kù)技術(shù)。對(duì)于Cache概念及組成知識(shí)你了解多少?下面小編整理了Cache概念及組成結(jié)構(gòu),供大家參閱。
基本概念
在計(jì)算機(jī)存儲(chǔ)系統(tǒng)的層次結(jié)構(gòu)中,介于中央處理器和主存儲(chǔ)器之間的高速小容量存儲(chǔ)器。它和主存儲(chǔ)器一起構(gòu)成一級(jí)的存儲(chǔ)器。高速緩沖存儲(chǔ)器和主存儲(chǔ)器之間信息的`調(diào)度和傳送是由硬件自動(dòng)進(jìn)行的。
某些機(jī)器甚至有二級(jí)三級(jí)緩存,每級(jí)緩存比前一級(jí)緩存速度慢且容量大。
組成結(jié)構(gòu)
高速緩沖存儲(chǔ)器是存在于主存與CPU之間的一級(jí)存儲(chǔ)器, 由靜態(tài)存儲(chǔ)芯片(SRAM)組成,容量比較小但速度比主存高得多, 接近于CPU的速度。
主要由三大部分組成:
Cache存儲(chǔ)體:存放由主存調(diào)入的指令與數(shù)據(jù)塊。
地址轉(zhuǎn)換部件:建立目錄表以實(shí)現(xiàn)主存地址到緩存地址的轉(zhuǎn)換。
替換部件:在緩存已滿時(shí)按一定策略進(jìn)行數(shù)據(jù)塊替換,并修改地址轉(zhuǎn)換部件。
補(bǔ)充說(shuō)明:Java 中常用緩存Cache機(jī)制的實(shí)現(xiàn)
緩存主要可分為二大類:
一、通過(guò)文件緩存,顧名思義文件緩存是指把數(shù)據(jù)存儲(chǔ)在磁盤(pán)上,不管你是以XML格式,序列化文件DAT格式還是其它文件格式;
二、內(nèi)存緩存,也就是實(shí)現(xiàn)一個(gè)類中靜態(tài)Map,對(duì)這個(gè)Map進(jìn)行常規(guī)的增刪查.
代碼如下 :
1. packagelhm.hcy.guge.frameset.cache;
2.
3. importjava.util.*;
4.
5. //Description:管理緩存
6.
7. //可擴(kuò)展的功能:當(dāng)chche到內(nèi)存溢出時(shí)必須清除掉最早期的一些緩存對(duì)象,這就要求對(duì)每個(gè)緩存對(duì)象保存創(chuàng)建時(shí)間
8.
9. publicclassCacheManager{
10. privatestaticHashMapcacheMap=newHashMap();
11.
12. //單實(shí)例構(gòu)造方法
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. //設(shè)置布爾值的緩存
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. //得到緩存。同步靜態(tài)方法
51. privatesynchronizedstaticCachegetCache(Stringkey){
52. return(Cache)cacheMap.get(key);
53. }
54.
55. //判斷是否存在一個(gè)緩存
56. privatesynchronizedstaticbooleanhasCache(Stringkey){
57. returncacheMap.containsKey(key);
58. }
59.
60. //清除所有緩存
61. publicsynchronizedstaticvoidclearAll(){
62. cacheMap.clear();
63. }
64.
65. //清除某一類特定緩存,通過(guò)遍歷HASHMAP下的所有對(duì)象,來(lái)判斷它的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);