SDWebImage 圖片下載緩存框架 常用方法及原理

常見面試題:
SDWebImage的最大并發(fā)數(shù)是多少门驾?_downloadQueue.maxConcurrentOperationCount = 6;
SDWebImages是如何識別圖片的登馒?NSData+ImageContentType.m中,根據(jù)圖片文件十六進制數(shù)據(jù)的第一個字節(jié)判斷



圖片的十六進制第一個字節(jié).png

SDWebImage 緩存圖片命名規(guī)則婴噩?為了防止名稱重復(fù),對其進行 md5 運算
默認下載的超時時長是多少?15秒
默認緩存的時間爬虱?一周_maxCacheAge = kDefaultCacheMaxCacheAge;static const NSInteger kDefaultCacheMaxCacheAge = 60 * 60 * 24 * 7; // 1 week
SDWebImage用什么類型緩存圖片?NSCacheSDImageCache內(nèi)處理內(nèi)存警告腾它,以通知的方式跑筝,clearMemory
cleanDisk的執(zhí)行過程i. 先遍歷所有的緩存文件,記錄過期的文件瞒滴,計算緩存文件的總大小ii. 刪除過期的文件iii. 判斷maxCacheSize的值是否>0曲梗,如果大于0再判斷緩存的文件總大小是否大于maxCacheSizeiv.如果緩存文件的總大小超過maxCacheSize,刪除最早的文件注意:.jpg妓忍、.gif等文件需要把擴展名填上虏两,png不需要

一、下載緩存

- (NSURL *)sd_imageURL;

2世剖、下載網(wǎng)絡(luò)圖片并緩存

1.- (void)sd_setImageWithURL:(NSURL *)url;
2.- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder;
3.- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options;
4.下載圖片的線程執(zhí)行完后回調(diào)
- (void)sd_setImageWithURL:(NSURL *)url completed: (SDWebImageCompletionBlock)completedBlock;
5.- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock;

6.- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock;

7.下載圖片并獲取圖片下載進度 progressBlock
- (void)sd_setImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock;

例子:下載圖片并且打印圖片的下載進度

NSURL *url = [NSURL URLWithString:@"http://picview01.baomihua.com/photos/20120624/m_14_634761470842343750_15728444.jpg"]; 
[self.imageView sd_setImageWithURL:url placeholderImage:nil options:0 progress:^(NSInteger receivedSize, NSInteger expectedSize) {
//乘1.0是為了轉(zhuǎn)換成float類型
float progress = receivedSize * 1.0 / expectedSize;
NSLog(@"下載進度 %f",progress);
} completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
NSLog(@"完成");
}];

8.先從本地緩存中查找請求的圖片定罢,如果有先用本地圖片占位,再從服務(wù)器請求下載圖片

- (void)sd_setImageWithPreviousCachedImageWithURL:(NSURL *)url placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options progress:(SDWebImageDownloaderProgressBlock)progressBlock completed:(SDWebImageCompletionBlock)completedBlock;

9.下載一組動畫圖片旁瘫,并自動播放動畫(arrayOfURLs為一組圖片的地址數(shù)組)
- (void)sd_setAnimationImagesWithURLs:(NSArray *)arrayOfURLs;
10.取消當前下載

- (void)sd_cancelCurrentAnimationImagesLoad;
12.設(shè)置是否顯示活的指示器以及樣式
注意:必須在請求下載圖片之前給UIImageView設(shè)置祖凫!不然無法顯示!

- (void)setShowActivityIndicatorView:(BOOL)show;
- (void)setIndicatorStyle:(UIActivityIndicatorViewStyle)style;

二境蜕、 UIButton的類擴展
#import "UIButton+WebCache.h"

1.獲取當前按鈕圖片的地址
- (NSURL *)sd_currentImageURL;
2.獲取指定狀態(tài)下按鈕圖片地址
- (NSURL *)sd_imageURLForState:(UIControlState)state;
3.設(shè)置不同UIControlState狀態(tài)下的按鈕圖片
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state;
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder;
- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options;

- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state completed:(SDWebImageCompletionBlock)completedBlock;

- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock;

- (void)sd_setImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock;

1.設(shè)置不同狀態(tài)的按鈕背景圖片
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state;

- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder;
- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options;

- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state completed:(SDWebImageCompletionBlock)completedBlock;

- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder completed:(SDWebImageCompletionBlock)completedBlock;

- (void)sd_setBackgroundImageWithURL:(NSURL *)url forState:(UIControlState)state placeholderImage:(UIImage *)placeholder options:(SDWebImageOptions)options completed:(SDWebImageCompletionBlock)completedBlock;

5.取消當前指定狀態(tài)按鈕圖片下載
- (void)sd_cancelImageLoadForState:(UIControlState)state;

6.取消當前指定狀態(tài)按鈕背景圖片下載
- (void)sd_cancelBackgroundImageLoadForState:(UIControlState)state;
三蝙场、參數(shù)介紹
options 枚舉:
1.SDWebImageRetryFailed 失敗后重試, 默認如果下載失敗,這個url會被加入黑名單并且不會嘗試再次下載,設(shè)置這個枚舉會阻止把失敗的url加入黑名單粱年,不斷嘗試重新下載
2.SDWebImageLowPriority 延遲下載售滤, 默認情況下,圖片會在交互發(fā)生的時候下載(例如你滑動tableview的時候),這個枚舉會禁止這個特性,導(dǎo)致的結(jié)果就是在scrollview減速的時候才會開始下載(也就是你滑動的時候scrollview不下載,你手從屏幕上移走,scrollview開始減速的時候才會開始下載圖片)
3.SDWebImageCacheMemoryOnly 只在內(nèi)存緩存
4.SDWebImageProgressiveDownload 漸進式下載,顯示的圖像是逐步在下載
5.SDWebImageRefreshCached 刷新緩存,有時本地圖片更新后與服務(wù)器沒有同步一致時可以使用(例如更新頭像)台诗,專門處理相同url完箩,但不同image的情況的
原因:默認情況下,SDWebImage會忽略Header中的緩存設(shè)置拉队,將圖片以url為key進行保存弊知,url與圖片是一一對應(yīng)關(guān)系。所以請求同一個url時粱快,SDWebImage會從緩存中取得圖片秩彤。一般的情況下用此方法可以滿足我們的應(yīng)用要求叔扼,但是如果你請求同一個url,而這張圖片在服務(wù)器端更新了漫雷,本地客戶端再次請求時還是會返回緩存中的舊圖片瓜富,例如加載頭像類經(jīng)常更新的圖片時,就會出現(xiàn)頭像不能更新的問題降盹,由于url與圖片一一對應(yīng)与柑,一種解決的辦法是改變部分url地址方式實現(xiàn)更新,不過這種方法操作起來很復(fù)雜蓄坏, 另一種將第三個參數(shù)設(shè)置為SDWebImageRefreshCached就可以實現(xiàn)圖片更新操作了价捧。
6.SDWebImageContinueInBackground 啟動后臺下載,app進入后臺后繼續(xù)下載
7.SDWebImageHandleCookies 處理存儲在NSHTTPCookieStore中的cookie

NSMutableURLRequest.HTTPShouldHandleCookies = YES;

8.SDWebImageAllowInvalidSSLCertificates 允許使用無效的SSL證書涡戳,主要用于測試目的结蟋,在正式環(huán)境中慎用
9.SDWebImageHighPriority 優(yōu)先下載
10.SDWebImageDelayPlaceholder 等待下載完成后再顯示占位圖片,延遲顯示占位圖片
11.SDWebImageTransformAnimatedImage 改變動畫形象
12.SDWebImageAvoidAutoSetImage 下載完成后手動設(shè)置圖片渔彰,默認是下載完成后自動放到ImageView上

SDWebImageCompletionBlock
typedef void(^SDWebImageCompletionBlock)(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL);
參數(shù):(1)請求的圖片
(2)請求圖片為空的錯誤
(3) SDImageCacheType 緩存類型椎眯,下次是從網(wǎng)上獲取還是從本地獲取, 枚舉:SDImageCacheTypeNone 永不緩存胳岂,但是從網(wǎng)上下載SDImageCacheTypeDisk 只緩存到磁盤上SDImageCacheTypeMemory 只緩存到內(nèi)存中
(4)圖片的網(wǎng)絡(luò)地址
SDWebImageDownloaderProgressBlock
typedef void(^SDWebImageDownloaderProgressBlock)(NSInteger receivedSize, NSInteger expectedSize);progress 參數(shù):receivedSize 接收到的字節(jié)數(shù)expectedSize 期望下載的字節(jié)數(shù)//乘1.0是為了轉(zhuǎn)換成float類型float progress = receivedSize * 1.0 / expectedSize;
四、本地緩存
#import"SDImageCache.h"
介紹:很多時候我們可能拍照得到的一張圖片要多個地方使用舔稀,那么我們就希望可以把這張圖片放到緩存里面乳丰,然后每次用這張圖片的時候就去通過特定的方式取即可。
屬性:
1.是否壓縮圖片
@property (assign, nonatomic) BOOL shouldDecompressImages;
2.是否禁用iCloud内贮,默認YES
@property (assign, nonatomic) BOOL shouldDisableiCloud;
3.是否緩存到內(nèi)存产园,默認YES
@property (assign, nonatomic) BOOL shouldCacheImagesInMemory;
4.最大緩存成本,針對內(nèi)存
@property (assign, nonatomic) NSUInteger maxMemoryCost;
5.最大緩存?zhèn)€數(shù)夜郁,針對內(nèi)存
@property (assign, nonatomic) NSUInteger maxMemoryCountLimit;
6.最大緩存時間什燕,單位:秒,針對磁盤緩存竞端,默認是一周屎即,自動把一星期以前緩存的圖片刪除掉
@property (assign, nonatomic) NSInteger maxCacheAge;
7.最大緩存大小,單位字節(jié)事富,針對磁盤技俐,默認無限制0,需要自己設(shè)置
@property (assign, nonatomic) NSUInteger maxCacheSize;

2统台、創(chuàng)建緩存空間
1.在沙盒的cache目錄下創(chuàng)建一個指定名字的緩存空間(文件夾)
- (id)initWithNamespace:(NSString *)ns;
2.在磁盤指定目錄(directory)下創(chuàng)建一個指定名字的緩存空間
- (id)initWithNamespace:(NSString *)ns diskCacheDirectory:(NSString *)directory;
3.添加一個只讀的緩存路徑
- (void)addReadOnlyCachePath:(NSString *)path;

3雕擂、緩存圖片到內(nèi)存和磁盤上
1.往內(nèi)存和磁盤上存儲一個圖片(key參數(shù)是唯一的,用來取出圖片贱勃,一般是圖片的絕對路徑)
- (void)storeImage:(UIImage *)image forKey:(NSString *)key;
例子:
SDImageCache *imageCache = [SDImageCache sharedImageCache];
[imageCache storeImage:image forKey:@"myphoto" toDisk:YES];
2.緩存一個圖片到內(nèi)存井赌,并設(shè)置是否緩存到磁盤上
- (void)storeImage:(UIImage *)image forKey:(NSString *)key toDisk:(BOOL)toDisk;
3.緩存的基礎(chǔ)方法谤逼,緩存一個圖片到內(nèi)存,并設(shè)置是否緩存到磁盤上(recalculate 是否重新計算圖片的data 仇穗, imageData 圖片的data)
- (void)storeImage:(UIImage *)image recalculateFromImage:(BOOL)recalculate imageData:(NSData *)imageData forKey:(NSString *)key toDisk:(BOOL)toDisk;
4流部、異步在磁盤上查找指定key圖片的緩存,完成后回調(diào)block
- (NSOperation *)queryDiskCacheForKey:(NSString *)key done:(SDWebImageQueryCompletedBlock)doneBlock;

5仪缸、從內(nèi)存贵涵、磁盤獲取指定key的圖片
- (UIImage *)imageFromMemoryCacheForKey:(NSString *)key;
- (UIImage *)imageFromDiskCacheForKey:(NSString *)key;

6、刪除指定key的圖片(fromDisk 是否刪除磁盤緩存恰画,completion刪除結(jié)束后回調(diào)無參block)
- (void)removeImageForKey:(NSString *)key;
- (void)removeImageForKey:(NSString *)key withCompletion:(SDWebImageNoParamsBlock)completion;
- (void)removeImageForKey:(NSString *)key fromDisk:(BOOL)fromDisk;
- (void)removeImageForKey:(NSString *)key fromDisk:(BOOL)fromDisk withCompletion:(SDWebImageNoParamsBlock)completion;

7宾茂、清除所有緩存
1.清除所有內(nèi)存圖片緩存
- (void)clearMemory;
2.清除所有磁盤緩存圖片時回調(diào)一個block
- (void)clearDiskOnCompletion:(SDWebImageNoParamsBlock)completion;
3.清除所有磁盤緩存
- (void)clearDisk;
4.從磁盤刪除所有過期的圖片時立即調(diào)用
- (void)cleanDiskWithCompletionBlock:(SDWebImageNoParamsBlock)completionBlock;
5.刪除所有磁盤上過期的緩存圖片
- (void)cleanDisk;

8、獲取緩存大小拴还、緩存?zhèn)€數(shù)
1.獲取磁盤緩存大小
- (NSUInteger)getSize;
2.獲取磁盤上緩存圖片的個數(shù)
- (NSUInteger)getDiskCount;
3.異步計算磁盤緩存的大小
- (void)calculateSizeWithCompletionBlock:(SDWebImageCalculateSizeBlock)completionBlock;

9跨晴、從磁盤查找緩存圖片
1.異步從磁盤中查找指定key的圖片緩存,查找完成后回調(diào)這個block(該block永遠在主線程執(zhí)行)
- (void)diskImageExistsWithKey:(NSString*)key completion:(SDWebImageCheckCacheCompletionBlock)completionBlock;
2.檢查磁盤中是否存在指定key的圖片緩存
- (BOOL)diskImageExistsWithKey:(NSString *)key;
3.通過圖片的key獲取其緩存路徑(path:緩存路徑的根路徑)
- (NSString*)cachePathForKey:(NSString*)key inPath:(NSString*)path;
4.從默認緩存路徑下獲取指定key圖片的路徑
- (NSString *)defaultCachePathForKey:(NSString *)key;

五片林、播放gif
#import "UIImage+GIF.h"

1.播放指定名字gif圖片
+ (UIImage *)sd_animatedGIFNamed:(NSString *)name;
2.用指定gif的data播放
+ (UIImage *)sd_animatedGIFWithData:(NSData *)data;
3.設(shè)置gif圖片尺寸
- (UIImage *)sd_animatedImageByScalingAndCroppingToSize:(CGSize)size;

六端盆、SDWebImage 實現(xiàn)原理

先講下大體架構(gòu):最外層是一個SDWebImageManager單例工具類管理另外兩個單例類,一個是作下載處理的SDWebImageDownloader费封,它管理多個下載操作SDWebImageDownloaderOperation焕妙,一個作緩存處理的SDImageCache。

大體執(zhí)行過程:當我們需要下載圖片時弓摘,先讓SDImageCache從緩存中找焚鹊,如果找不到就異步從硬盤中讀取圖片,如果讀取到就將圖片緩存到內(nèi)存并回調(diào)給SDWebImageManager韧献,如果找不到就讓SDWebImageDownloader 執(zhí)行下載操作末患,在 SDWebImageDownloaderOperation 單個圖片的下載操作中利用 NSURLConnection 執(zhí)行下載,實現(xiàn)代理監(jiān)聽下載進度等锤窑,下載完成后交給SDWebImageDecoder 圖片異步解碼璧针,完成后回調(diào)給SDWebImageDownloader,再回調(diào)給SDWebImageManager渊啰,再讓SDImageCache去執(zhí)行內(nèi)存和磁盤(異步)的緩存操作探橱。

具體過程:

1.UIImageView+WebCache: setImageWithURL:placeholderImage:options: 先顯示 placeholderImage ,同時由SDWebImageManager 根據(jù) URL 來在本地查找圖片虽抄。
2.SDWebImageManager: downloadWithURL:delegate:options:userInfo: SDWebImageManager是將UIImageView+WebCache同SDImageCache鏈接起來的類走搁, SDImageCache: queryDiskCacheForKey:delegate:userInfo:用來從緩存根據(jù)CacheKey查找圖片是否已經(jīng)在緩存中
3.如果內(nèi)存中已經(jīng)有圖片緩存, SDWebImageManager會回調(diào)SDImageCacheDelegate : imageCache:didFindImage:forKey:userInfo:
而 UIImageView+WebCache 則回調(diào)SDWebImageManagerDelegate: webImageManager:didFinishWithImage:來顯示圖片迈窟。
4.如果內(nèi)存中沒有圖片緩存私植,那么生成 NSInvocationOperation 添加到隊列,從硬盤查找圖片是否已被下載緩存车酣。
根據(jù) URLKey 在硬盤緩存目錄下嘗試讀取圖片文件曲稼。這一步是在 NSOperation 進行的操作索绪,所以回主線程進行結(jié)果回調(diào)
notifyDelegate:
5.如果上一操作從硬盤讀取到了圖片,將圖片添加到內(nèi)存緩存中(如果空閑內(nèi)存過小贫悄,會先清空內(nèi)存緩存)瑞驱。SDImageCacheDelegate 回調(diào) imageCache:didFindImage:forKey:userInfo:進而回調(diào)展示圖片。
6.如果從硬盤緩存目錄讀取不到圖片窄坦,說明所有緩存都不存在該圖片唤反,需要下載圖片,回調(diào)
imageCache:didNotFindImageForKey:userInfo:
共享或重新生成一個下載器 SDWebImageDownloader 開始下載圖片鸭津。
圖片下載由 NSURLConnection 來做彤侍,實現(xiàn)相關(guān) delegate 來判斷圖片下載中、下載完成和下載失敗逆趋。
connection:didReceiveData: 中利用 ImageIO 做了按圖片下載進度加載效果盏阶。
connectionDidFinishLoading: 數(shù)據(jù)下載完成后交給 SDWebImageDecoder 做圖片解碼處理。
圖片解碼處理在一個 NSOperationQueue 完成闻书,不會拖慢主線程 UI名斟。
7.如果有需要對下載的圖片進行二次處理,最好也在這里完成魄眉,效率會好很多砰盐。
在主線程 notifyDelegateOnMainThreadWithInfo: 宣告解碼完成,imageDecoder:didFinishDecodingImage:userInfo: 回調(diào)給 SDWebImageDownloader坑律。
imageDownloader:didFinishWithImage: 回調(diào)給 SDWebImageManager 告知圖片下載完成楞卡。
通知所有的 downloadDelegates 下載完成,回調(diào)給需要的地方展示圖片脾歇。
將圖片保存到 SDImageCache 中,內(nèi)存緩存和硬盤緩存同時保存淘捡。
寫文件到硬盤在單獨 NSInvocationOperation 中完成藕各,避免拖慢主線程。
8.如果是在iOS上運行焦除,SDImageCache 在初始化的時候會注冊notification 到 UIApplicationDidReceiveMemoryWarningNotification 以及 UIApplicationWillTerminateNotification,在內(nèi)存警告的時候清理內(nèi)存圖片緩存激况,應(yīng)用結(jié)束的時候清理過期圖片。
SDWebImagePrefetcher 可以預(yù)先下載圖片膘魄,方便后續(xù)使用乌逐。

轉(zhuǎn)載

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市创葡,隨后出現(xiàn)的幾起案子浙踢,更是在濱河造成了極大的恐慌,老刑警劉巖灿渴,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洛波,死亡現(xiàn)場離奇詭異胰舆,居然都是意外死亡,警方通過查閱死者的電腦和手機蹬挤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進店門缚窿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人焰扳,你說我怎么就攤上這事倦零。” “怎么了吨悍?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵扫茅,是天一觀的道長。 經(jīng)常有香客問我畜份,道長诞帐,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任爆雹,我火速辦了婚禮停蕉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘钙态。我一直安慰自己慧起,他們只是感情好,可當我...
    茶點故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布册倒。 她就那樣靜靜地躺著蚓挤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪驻子。 梳的紋絲不亂的頭發(fā)上灿意,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天,我揣著相機與錄音崇呵,去河邊找鬼缤剧。 笑死,一個胖子當著我的面吹牛域慷,可吹牛的內(nèi)容都是我干的荒辕。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼犹褒,長吁一口氣:“原來是場噩夢啊……” “哼抵窒!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起叠骑,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤李皇,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后宙枷,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體疙赠,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡付材,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了圃阳。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片厌衔。...
    茶點故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖捍岳,靈堂內(nèi)的尸體忽然破棺而出富寿,到底是詐尸還是另有隱情,我是刑警寧澤锣夹,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布页徐,位于F島的核電站,受9級特大地震影響银萍,放射性物質(zhì)發(fā)生泄漏变勇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一贴唇、第九天 我趴在偏房一處隱蔽的房頂上張望搀绣。 院中可真熱鬧,春花似錦戳气、人聲如沸链患。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽麻捻。三九已至,卻和暖如春呀袱,著一層夾襖步出監(jiān)牢的瞬間贸毕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工夜赵, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留崖咨,地道東北人。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓油吭,卻偏偏與公主長得像,于是被迫代替她去往敵國和親署拟。 傳聞我的和親對象是個殘疾皇子婉宰,可洞房花燭夜當晚...
    茶點故事閱讀 44,976評論 2 355

推薦閱讀更多精彩內(nèi)容