- 相關(guān)推薦
Cache概念及組成結(jié)構(gòu)
Cache,是 一種后關(guān)系型數(shù)據(jù)庫。能并發(fā)訪問同一數(shù)據(jù)的數(shù)據(jù)庫技術(shù)。對于Cache概念及組成知識你了解多少?下面小編整理了Cache概念及組成結(jié)構(gòu),供大家參閱。
基本概念
在計算機存儲系統(tǒng)的層次結(jié)構(gòu)中,介于中央處理器和主存儲器之間的高速小容量存儲器。它和主存儲器一起構(gòu)成一級的存儲器。高速緩沖存儲器和主存儲器之間信息的調(diào)度和傳送是由硬件自動進行的。
某些機器甚至有二級三級緩存,每級緩存比前一級緩存速度慢且容量大。
組成結(jié)構(gòu)
高速緩沖存儲器是存在于主存與CPU之間的一級存儲器, 由靜態(tài)存儲芯片(SRAM)組成,容量比較小但速度比主存高得多, 接近于CPU的速度。
主要由三大部分組成:
Cache存儲體:存放由主存調(diào)入的指令與數(shù)據(jù)塊。
地址轉(zhuǎn)換部件:建立目錄表以實現(xiàn)主存地址到緩存地址的轉(zhuǎn)換。
替換部件:在緩存已滿時按一定策略進行數(shù)據(jù)塊替換,并修改地址轉(zhuǎn)換部件。
補充說明:Java 中常用緩存Cache機制的實現(xiàn)
緩存主要可分為二大類:
一、通過文件緩存,顧名思義文件緩存是指把數(shù)據(jù)存儲在磁盤上,不管你是以XML格式,序列化文件DAT格式還是其它文件格式;
二、內(nèi)存緩存,也就是實現(xiàn)一個類中靜態(tài)Map,對這個Map進行常規(guī)的增刪查.
代碼如下 :
1. packagelhm.hcy.guge.frameset.cache;
2.
3. importjava.util.*;
4.
5. //Description:管理緩存
6.
7. //可擴展的功能:當chche到內(nèi)存溢出時必須清除掉最早期的一些緩存對象,這就要求對每個緩存對象保存創(chuàng)建時間
8.
9. publicclassCacheManager{
10. privatestaticHashMapcacheMap=newHashMap();
11.
12. //單實例構(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. //判斷是否存在一個緩存
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);
【Cache概念及組成結(jié)構(gòu)】相關(guān)文章:
現(xiàn)代物流管理的觀念及流程10-30
高等級公路的組成02-24
計算機的組成及工作原理07-02
毛概考試試題論述題及答案02-07
網(wǎng)球拍組成部分有哪些06-17
組成領(lǐng)導力的十三大要素05-29
如何優(yōu)化企業(yè)資本結(jié)構(gòu)07-05
計算機硬件系統(tǒng)的組成有哪些12-12