緩存

爲了節約流量,同時也是爲了更好的用戶體驗,目前不少應用都使用本地緩存機制,其中以網易新聞的緩存功能最爲出色。我本身的應用也想加入本地緩存的功能,因而我從網上查閱了相關的資料,發現整體上說有兩種方法。一種是本身寫緩存的處理,一種是採用ASIHTTPRequest中的ASIDownloadCache。緩存


方法一:通常將服務器第一次返回的數據保存在沙盒裏面。這樣在手機斷網的狀況下能夠從本地讀取數據了。服務器

1.保存到沙盒的代碼:app

 

[plain] view plaincopyatom

  1. + (void)saveCache:(int)type andID:(int)_id andString:(NSString *)str;  url

  2. {  spa

  3.     NSUserDefaults * setting = [NSUserDefaults standardUserDefaults];  .net

  4.     NSString * key = [NSString stringWithFormat:@"detail-%d-%d",type, _id];  orm

  5.     [setting setObject:str forKey:key];  blog

  6.     [setting synchronize];  ip

  7. }  


2.讀取本地沙盒的代碼

 

讀取以前首先根據type和Id判斷本地是否有

 

[plain] view plaincopy

  1. + (NSString *)getCache:(int)type andID:(int)_id  

  2. {  

  3.     NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];  

  4.     NSString *key = [NSString stringWithFormat:@"detail-%d-%d",type, _id];  

  5.       

  6.     NSString *value = [settings objectForKey:key];  

  7.     return value;  

  8. }  


若是沙盒裏面有數據

 

[plain] view plaincopy

  1. NSString *value = [Tool getCache:5 andID:self.QiuTime];  

  2.         if (value) {  

  3.             NSDictionary *backdict = [value JSONValue];  

  4.             if ([backdict objectForKey:@"items"]) {  

  5.                 NSArray *array=[NSArray arrayWithArray:[backdict objectForKey:@"items"]];  

  6.                 for (NSDictionary *qiushi in array) {  

  7.                     QiuShi *qs=[[[QiuShi alloc]initWithDictionary:qiushi] autorelease];  

  8.                     [self.list addObject:qs];  

  9.                 }  

  10.             }  

  11.             [self.tableView reloadData];  

  12.              

  13.         }  

  14.           

  15.         [self.tableView tableViewDidFinishedLoadingWithMessage:@"數據所有加載完了.."];  

  16.         self.tableView.reachedTheEnd  = YES;  

 

方法二:使用ASIHTTPRequest和ASIDownloadCache實現本地緩存

 

一、設置全局的Cache
    在AppDelegate.h中添加一個全局變量

 

[plain] view plaincopy

  1. @interface AppDelegate : UIResponder   

  2. {  

  3.     ASIDownloadCache *myCache;  

  4. }  

  5. @property (strong, nonatomic) UIWindow *window;  

  6. @property (nonatomic,retain) ASIDownloadCache *myCache;  


   在AppDelegate.m中的- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions方法中添加以下代碼

 

 

[plain] view plaincopy

  1. //自定義緩存  

  2. ASIDownloadCache *cache = [[ASIDownloadCache alloc] init];  

  3. self.myCache = cache;  

  4. [cache release];  

  5.       

  6. //設置緩存路徑  

  7. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);  

  8. NSString *documentDirectory = [paths objectAtIndex:0];  

  9. [self.myCache setStoragePath:[documentDirectory stringByAppendingPathComponent:@"resource"]];  

  10. [self.myCache setDefaultCachePolicy:ASIOnlyLoadIfNotCachedCachePolicy];  

    

 

    在AppDelegate.m中的dealloc方法中添加以下語句

 

[plain] view plaincopy

  1. [myCache release];  


    到這裏爲止,就完成了全局變量的聲明。

 

    二、設置緩存策略

    在實現ASIHTTPRequest請求的地方設置request的存儲方式,代碼以下

 

[plain] view plaincopy

  1. NSString *str = @"http://....../getPictureNews.aspx";  

  2. NSURL *url = [NSURL URLWithString:str];  

  3. ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];  

  4. //獲取全局變量  

  5. AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];  

  6. //設置緩存方式  

  7. [request setDownloadCache:appDelegate.myCache];  

  8. //設置緩存數據存儲策略,這裏採起的是若是無更新或沒法聯網就讀取緩存數據  

  9. [request setCacheStoragePolicy:ASICachePermanentlyCacheStoragePolicy];  

  10. request.delegate = self;  

  11. [request startAsynchronous];  


    三、清理緩存數據

 

    我在這裏採用的是手動清理數據的方式,在適當的地方添加以下代碼,我將清理緩存放在了應用的設置模塊:

 

[plain] view plaincopy

  1. AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];  

  2. [appDelegate.myCache clearCachedResponsesForStoragePolicy:ASICachePermanentlyCacheStoragePolicy];  

相關文章
相關標籤/搜索