青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

red22

通過STL實現(xiàn)帶LRU的Cache

        開發(fā)互聯(lián)網(wǎng)的server系統(tǒng),難免會用一些cache機制,通常在Linux下多使用共享內(nèi)存機制,把分配的內(nèi)存組織成一個特定的數(shù)據(jù)結構,用來緩存后端DB的數(shù)據(jù),加速讀寫。但是對一些新手而言,共享內(nèi)存的使用還是有一些門檻,與此同時STL的使用卻是相對容易上手,所以可以通過STL的容器組合出一個cache來。

        上網(wǎng)搜了一下,看到已經(jīng)有人做了一些類似的事情,具體可以參看http://bytes.com/forum/thread640146.html,作者采用STL::map(當然也可以是hash_map做數(shù)據(jù)緩存cache),采用一個list做lru鏈,每當讀寫cache中的數(shù)據(jù)時,都要在lru鏈中刪除該key值對應的項,并把該數(shù)據(jù)的key值重新放到頭部,這里面有個相對較慢的地方就是從lru鏈中刪除key值對應的項的操作,因為刪除操作表面看也僅是erase,但是其中也是順序查找出來再刪,相對耗時。可以針對此對之進行改進。

         采用STL::map做lru鏈,map::first是一個“虛時間”,表示訪問某一個key的虛時間,map::second就是key值,同樣另外一個map做cache緩存數(shù)據(jù),first為key,second為(value,virtual_time)對,這樣當讀寫一個key的數(shù)據(jù)時,可以快速定位到該數(shù)據(jù),并且可以查找到它的上次訪問時間,從而在lru鏈里面快速定位(樹上的查找終究要快)并刪除,再更新key的訪問時間并插入到lru鏈中就可以了。

         當cache過大了,比如緩存最多100,那么就可以從lru鏈的頭部開始淘汰了,(因為lru鏈first值越小,表示訪問越久了)。代碼貼在下面,歡迎批評指證。與上面文章里的相比,代碼簡化了給多,這樣比較方便閱讀,另外考慮到數(shù)據(jù)多是blob,所以cache中的value就采用stl::string了。

         STL做cache的幾個缺點:

        1 由于cache的數(shù)據(jù)在堆棧中,所以server一旦core掉就丟了;

        2 鑒于上述原因,所以這種cache適合“讀多寫少”的業(yè)務,一旦有“寫入”操作,就和數(shù)據(jù)庫同步更新,這樣的話淘汰的時候也比較簡單,直接丟掉就好了,不存在“臟數(shù)據(jù)”的概念。

        當然,對于海量用戶訪問的業(yè)務,還是建議用共享內(nèi)存做cache機制,這樣讀寫的效率都會提高,并且程序出問題數(shù)據(jù)仍然在,但是壞處就是會帶來復雜性和好多其它的問題,就不在這里說了。

#ifndef _MAP_LRU_CACHE_H_
#define _MAP_LRU_CACHE_H_

#include <string.h>

#include <iostream>
#include <list>
#include <map>

using namespace std;

namespace lru_cache {

        static const int DEF_CAPACITY = 100000;

        typedef unsigned long long virtual_time;

        typedef struct _HashKey
        {// key的類型自定義,重要的是要overload <和==

        }HashKey;

        typedef struct _HashValue
        {
                string value_;
                virtual_time access_;
        }HashValue;


        class CLRUCache
        {
                public:

                        CLRUCache() : _lru_list(), _hash_table(), _now(0){}
                        virtual ~CLRUCache(){}

                        int set( const HashKey& key, const string &value );
                        HashValue* get( const HashKey& key );


                        unsigned get_lru_list_size(){ return (unsigned)_lru_list.size(); }
                        unsigned get_hash_table_size() { return (unsigned)_hash_table.size(); }
                        virtual_time get_now() { return _now; }

                 private:

                        virtual_time get_virtual_time()
                        {
                                return ++_now;
                        }

                        map<virtual_time, HashKey>    _lru_list;
                        map<HashKey, HashValue> _hash_table;
                        virtual_time _now;
        };

}
#endif

#include "map_lru_cache.h"

using namespace lru_cache;

int CLRUCache::set( const HashKey& key, const string &value )
{
        HashValue hash_value;
        hash_value.value_ = value;
        hash_value.access_ = get_virtual_time();

        pair< map<HashKey, HashValue>::iterator, bool > ret = _hash_table.insert(make_pair(key, hash_value));

        if ( !ret.second )
        {
                // key already exist
                virtual_time old_access = _hash_table[key].access_;
                map<virtual_time, HashKey>::iterator iter = _lru_list.find(old_access);
                if(iter != _lru_list.end())
                {
                        _lru_list.erase(iter);
                }

                _lru_list.insert(make_pair(hash_value.access_, key));
                _hash_table[key] = hash_value;


        }

        else
        {
                _lru_list.insert(make_pair(hash_value.access_, key));

                if ( _hash_table.size() > DEF_CAPACITY ) //ÌÔÌ­
                {
                        // get the least recently used key
                        map<virtual_time, HashKey>::iterator iter = _lru_list.begin();


                        _hash_table.erase( iter->second );
                        // remove last key from list
                        _lru_list.erase(iter);
                }
        }
        return 0;
}

HashValue* CLRUCache::get( const HashKey& key )
{
        map<HashKey, HashValue>::iterator iter = _hash_table.find(key);
        if ( iter != _hash_table.end() )
        {
                virtual_time old_access = iter->second.access_;
                iter->second.access_ = get_virtual_time();

                map<virtual_time, HashKey>::iterator it = _lru_list.find(old_access);
                if(it != _lru_list.end())
                {
                        _lru_list.erase(it);
                }

                _lru_list.insert(make_pair(iter->second.access_, key));

                return &(iter->second);
        }

        else
                return NULL;
}

posted on 2008-09-22 15:21 red22 閱讀(3647) 評論(1)  編輯 收藏 引用

Feedback

# re: 通過STL實現(xiàn)帶LRU的Cache 2015-01-17 15:01 后知后覺

基于C++實現(xiàn)的LRU的cache  回復  更多評論   



只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


My Links

Blog Stats

常用鏈接

留言簿

文章檔案

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩国产bt| 免费日韩精品中文字幕视频在线| 欧美激情国产日韩精品一区18| 国语自产精品视频在线看| 香蕉久久夜色| 午夜精品久久久久久久99黑人| 国产欧美一区二区在线观看| 欧美在线精品免播放器视频| 欧美在线视频免费观看| 国产色视频一区| 久久在线免费| 久久永久免费| 日韩视频在线免费| 亚洲第一页在线| 欧美另类视频在线| 亚洲精品色婷婷福利天堂| 日韩视频国产视频| 欧美日韩一卡二卡| 亚洲一区二区动漫| 亚洲一区二区欧美| 国产精品国产三级国产专播品爱网| 久久本道综合色狠狠五月| 久久gogo国模裸体人体| 在线日韩av片| 亚洲免费成人| 国产日韩欧美麻豆| 久久男人av资源网站| 免费一区视频| 亚洲一区免费在线观看| 欧美在线高清视频| 在线观看不卡av| 91久久精品美女| 国产精品自在线| 欧美激情亚洲自拍| 欧美日韩不卡合集视频| 久久成人免费电影| 久久久成人网| 亚洲丝袜av一区| 久久久久久尹人网香蕉| 亚洲视频一区| 久久久久久9999| 亚洲无毛电影| 老司机免费视频一区二区三区| 亚洲欧美日韩一区二区在线 | 欧美一级大片在线免费观看| 久久久99久久精品女同性| 一本大道久久精品懂色aⅴ| 亚洲一区二区3| 亚洲国产日韩在线一区模特| 久久不射网站| 亚洲天堂网站在线观看视频| 牛牛国产精品| 久久人人97超碰精品888| 欧美日本簧片| 欧美成ee人免费视频| 国产欧美精品在线播放| 99riav久久精品riav| 亚洲国内欧美| 久久久国产精品一区二区三区| 香蕉成人久久| 欧美新色视频| 亚洲乱码久久| 亚洲精品国产精品国自产观看| 久久久久国产精品www| 欧美淫片网站| 国产精品亚洲不卡a| 日韩午夜在线观看视频| 日韩一区二区高清| 久久精品视频在线| 午夜精品在线看| 国产精品乱码一区二三区小蝌蚪| 日韩一级裸体免费视频| 一本色道久久综合亚洲精品不卡| 欧美日韩不卡合集视频| 亚洲人午夜精品免费| 亚洲精品在线观看免费| 欧美成人首页| 亚洲国产一区二区a毛片| 亚洲欧洲日本mm| 欧美多人爱爱视频网站| 91久久久久久国产精品| 日韩午夜在线电影| 麻豆精品视频| 亚洲国产黄色| 中文国产成人精品久久一| 欧美日韩中文| 亚洲在线免费观看| 在线亚洲国产精品网站| 欧美午夜精品一区| 亚洲理论电影网| 亚洲欧美激情视频| 国产精品久久久久一区| 亚洲欧美韩国| 毛片av中文字幕一区二区| 在线观看欧美日韩| 久久午夜视频| 日韩一区二区电影网| 性伦欧美刺激片在线观看| 国产小视频国产精品| 久久久久国色av免费观看性色| 亚洲高清久久久| 亚洲天堂av高清| 国产一区二区中文字幕免费看| 免费成年人欧美视频| 亚洲伦理在线观看| 亚洲欧美国产精品va在线观看 | 欧美精品网站| 亚洲性xxxx| 免费一级欧美片在线播放| 亚洲美女中文字幕| 欧美日韩国产片| 香蕉乱码成人久久天堂爱免费| 亚洲电影观看| 欧美综合国产精品久久丁香| 亚洲精品无人区| 国产区日韩欧美| 欧美韩国日本综合| 亚洲午夜久久久| 欧美激情小视频| 久久国产主播| 亚洲一级二级在线| 国产欧美激情| 欧美久久久久中文字幕| 欧美一级艳片视频免费观看| 最新日韩中文字幕| 久久国产精品久久国产精品| 9国产精品视频| 在线播放日韩欧美| 欧美日韩三级视频| 欧美一级一区| 亚洲午夜视频在线观看| 亚洲成色最大综合在线| 久久久久久穴| 午夜欧美精品| 一本大道久久精品懂色aⅴ| 激情视频一区| 国产婷婷色一区二区三区| 欧美国产日韩亚洲一区| 久久午夜羞羞影院免费观看| 欧美综合国产精品久久丁香| 亚洲免费网站| 亚洲视频中文| 99国内精品久久| 亚洲理论电影网| 91久久精品国产91久久| 欧美成人国产| 乱人伦精品视频在线观看| 欧美影片第一页| 午夜亚洲视频| 亚洲免费在线视频| 亚洲久久成人| 亚洲人www| 亚洲日本中文字幕| 国产一区二区三区久久悠悠色av | 99视频一区二区| 亚洲精品在线视频| 黑人巨大精品欧美一区二区| 悠悠资源网久久精品| 极品裸体白嫩激情啪啪国产精品 | 欧美日韩国产美女| 久久中文字幕导航| 欧美影片第一页| 久久精品亚洲国产奇米99| 欧美主播一区二区三区| 久久精品首页| 欧美~级网站不卡| 欧美精品一区二区三区四区| 国产精品草莓在线免费观看| 国产日韩三区| 亚洲丶国产丶欧美一区二区三区| 日韩视频免费观看高清在线视频 | 老司机免费视频一区二区| 久久人人爽人人| 免费在线成人| 亚洲毛片在线看| 亚洲欧美999| 理论片一区二区在线| 欧美另类videos死尸| 欧美日韩中文在线观看| 国产美女精品免费电影| 在线观看一区视频| 精品二区视频| 一区二区三区国产精品| 午夜精品久久久久影视| 久久天天狠狠| 日韩视频在线观看免费| 亚洲综合电影| 另类专区欧美制服同性| 欧美日韩亚洲视频| 国产精品久久久久高潮| 狠狠色综合网站久久久久久久| 一区二区三区视频免费在线观看| 久久国产精品久久久久久电车 | 久久国产精品久久久久久久久久 | 亚洲欧美综合v| 欧美不卡视频一区发布| 一区二区日韩免费看| 久久婷婷综合激情| 欧美日韩国产经典色站一区二区三区| 国产亚洲一区二区精品|