You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

60 lines
1.5 KiB

//
// DLFIFOCache.m
// DLSlideViewDemo
//
// Created by Dongle Su on 14-12-13.
// Copyright (c) 2014年 dongle. All rights reserved.
//
#import "DLLRUCache.h"
@implementation DLLRUCache{
NSMutableDictionary *dic_;
NSMutableArray *lruKeyList_;
NSInteger capacity_;
}
- (id)initWithCount:(NSInteger)count{
if (self = [super init]) {
capacity_ = count;
dic_ = [NSMutableDictionary dictionaryWithCapacity:capacity_];
lruKeyList_ = [NSMutableArray arrayWithCapacity:capacity_];
}
return self;
}
- (void)setObject:(id)object forKey:(NSString *)key{
if (![lruKeyList_ containsObject:key]) {
if (lruKeyList_.count < capacity_) {
[dic_ setValue:object forKey:key];
[lruKeyList_ addObject:key];
}
else{
NSString *longTimeUnusedKey = [lruKeyList_ firstObject];
[dic_ setValue:nil forKey:longTimeUnusedKey];
[lruKeyList_ removeObjectAtIndex:0];
[dic_ setValue:object forKey:key];
[lruKeyList_ addObject:key];
}
}
else{
[dic_ setValue:object forKey:key];
[lruKeyList_ removeObject:key];
[lruKeyList_ addObject:key];
}
}
- (id)objectForKey:(NSString *)key{
if ([lruKeyList_ containsObject:key]) {
[lruKeyList_ removeObject:key];
[lruKeyList_ addObject:key];
return [dic_ objectForKey:key];
}
else{
return nil;
}
}
@end