KQueue.m 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. //
  2. // KQueue.m
  3. // KacheDemo
  4. //
  5. // Created by jiajun on 7/25/12.
  6. // Copyright (c) 2012 __MyCompanyName__. All rights reserved.
  7. //
  8. #import "KConfig.h"
  9. #import "KHolder.h"
  10. #import "KObject.h"
  11. #import "KQueue.h"
  12. #import "KUtil.h"
  13. @interface KQueue ()
  14. @property (strong, nonatomic) KHolder *holder;
  15. @property (assign, nonatomic) NSInteger offset;
  16. @property (strong, atomic) NSMutableArray *queue;
  17. - (void)cleanExpiredObjects;
  18. @end
  19. @implementation KQueue
  20. @synthesize holder = _holder;
  21. @synthesize name = _name;
  22. @synthesize offset = _offset;
  23. @synthesize queue = _queue;
  24. @synthesize size = _size;
  25. #pragma mark - init
  26. - (KQueue *)initWithHolder:(KHolder *)aHolder
  27. {
  28. self = [super init];
  29. if (self) {
  30. self.holder = aHolder;
  31. self.queue = [[NSMutableArray alloc] init];
  32. self.size = KACHE_DEFAULT_QUEUE_SIZE;
  33. self.offset = 0;
  34. return self;
  35. }
  36. return nil;
  37. }
  38. #pragma mark - private
  39. - (void)cleanExpiredObjects
  40. {
  41. if (self.queue && 0 < [self.queue count]) {
  42. for (int i = 0; i < [self.queue count] - 1; i ++) {
  43. NSString *tmpKey = [self.queue objectAtIndex:i];
  44. KObject *leftObject = [self.holder objectForKey:tmpKey];
  45. if ([leftObject expiredTimestamp] < [KUtil nowTimestamp]) {
  46. [self.queue removeObject:tmpKey];
  47. }
  48. else {
  49. break;
  50. }
  51. }
  52. }
  53. }
  54. #pragma mark - public
  55. - (void)push:(id)data
  56. {
  57. NSString *key = [NSString stringWithFormat:@"QUEUE_%@_%d", self.name, self.offset];
  58. self.offset ++;
  59. [self.holder setValue:data forKey:key expiredAfter:0];
  60. [self cleanExpiredObjects];
  61. if (self.size <= [self.queue count]) {
  62. [self.holder removeObjectForKey:[self.queue objectAtIndex:0]];
  63. [self.queue removeObjectAtIndex:0];
  64. }
  65. [self.queue addObject:key];
  66. }
  67. - (id)pop
  68. {
  69. if (0 < [self.queue count]) {
  70. NSString *key = [self.queue objectAtIndex:0];
  71. [self.queue removeObjectAtIndex:0];
  72. KObject *object = [self.holder objectForKey:key];
  73. [self.holder removeObjectForKey:key];
  74. return [object value];
  75. }
  76. return nil;
  77. }
  78. // Convert object to NSDictionary.
  79. - (NSDictionary *)serialize
  80. {
  81. return [NSDictionary dictionaryWithObjectsAndKeys:
  82. [NSString stringWithFormat:@"%d", self.size], @"size",
  83. self.name, @"name",
  84. self.queue, @"queue",
  85. [NSString stringWithFormat:@"%d", self.offset], @"offset",
  86. nil];
  87. }
  88. // Convert NSDictionary to object.
  89. - (void)unserializeFrom:(NSDictionary *)dict
  90. {
  91. if ([[dict allKeys] containsObject:@"size"]
  92. && [[dict allKeys] containsObject:@"name"]
  93. && [[dict allKeys] containsObject:@"queue"]
  94. && [[dict allKeys] containsObject:@"offset"]) {
  95. self.size = [[dict objectForKey:@"size"] intValue];
  96. self.name = [NSString stringWithFormat:@"%@", [dict objectForKey:@"name"]];
  97. self.queue = [[dict objectForKey:@"queue"] mutableCopy];
  98. self.offset = [[dict objectForKey:@"offset"] intValue];
  99. }
  100. }
  101. @end