当C++遇到IOS应用开发---LRUCache缓存(4)

来源:未知 责任编辑:责任编辑 发表时间:2014-01-20 07:51 点击:

            _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* 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(); 
            //调整当前key在LRU列表中的位置 
            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)); 
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • Lexical or Preprocessor Issue 'xxx.h
  • ios学习笔记(二)xcode 4.3.2下实现基本交互
  • ios版本的helloworld
  • iphone(object-c) 内存管理(3) 有效的内存管理 前半部分
  • ios学习笔记(一)xcode 4.3.2下创建第一个ios项目
  • IOS类似iphone通讯录TableView的完整demo【附源码】
  • UITableView一些方法
  • [iPhone中级]iPhone团购信息客户端的开发 (二)
  • 如何为Iphone应用创建启动界面
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1