亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

硬件維護(hù) 百文網(wǎng)手機(jī)站

Cache概念及組成結(jié)構(gòu)

時(shí)間:2022-03-21 14:52:49 硬件維護(hù) 我要投稿

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);