172 lines
5.7 KiB
Markdown
172 lines
5.7 KiB
Markdown
|
YYCache
|
|||
|
==============
|
|||
|
|
|||
|
[![License MIT](https://img.shields.io/badge/license-MIT-green.svg?style=flat)](https://raw.githubusercontent.com/ibireme/YYCache/master/LICENSE)
|
|||
|
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
|
|||
|
[![CocoaPods](http://img.shields.io/cocoapods/v/YYCache.svg?style=flat)](http://cocoapods.org/?q= YYCache)
|
|||
|
[![CocoaPods](http://img.shields.io/cocoapods/p/YYCache.svg?style=flat)](http://cocoapods.org/?q= YYCache)
|
|||
|
[![Support](https://img.shields.io/badge/support-iOS%206%2B%20-blue.svg?style=flat)](https://www.apple.com/nl/ios/)
|
|||
|
[![Build Status](https://travis-ci.org/ibireme/YYCache.svg?branch=master)](https://travis-ci.org/ibireme/YYCache)
|
|||
|
|
|||
|
High performance cache framework for iOS.<br/>
|
|||
|
(It's a component of [YYKit](https://github.com/ibireme/YYKit))
|
|||
|
|
|||
|
Performance
|
|||
|
==============
|
|||
|
|
|||
|
![Memory cache benchmark result](https://raw.github.com/ibireme/YYCache/master/Benchmark/Result_memory.png
|
|||
|
)
|
|||
|
|
|||
|
![Disk benchmark result](https://raw.github.com/ibireme/YYCache/master/Benchmark/Result_disk.png
|
|||
|
)
|
|||
|
|
|||
|
You may [download](http://www.sqlite.org/download.html) and compile the latest version of sqlite and ignore the libsqlite3.dylib in iOS system to get higher performance.
|
|||
|
|
|||
|
See `Benchmark/CacheBenchmark.xcodeproj` for more benchmark case.
|
|||
|
|
|||
|
|
|||
|
Features
|
|||
|
==============
|
|||
|
- **LRU**: Objects can be evicted with least-recently-used algorithm.
|
|||
|
- **Limitation**: Cache limitation can be controlled with count, cost, age and free space.
|
|||
|
- **Compatibility**: The API is similar to `NSCache`, all methods are thread-safe.
|
|||
|
- **Memory Cache**
|
|||
|
- **Release Control**: Objects can be released synchronously/asynchronously on main thread or background thread.
|
|||
|
- **Automatically Clear**: It can be configured to automatically evict objects when receive memory warning or app enter background.
|
|||
|
- **Disk Cache**
|
|||
|
- **Customization**: It supports custom archive and unarchive method to store object which does not adopt NSCoding.
|
|||
|
- **Storage Type Control**: It can automatically decide the storage type (sqlite / file) for each object to get
|
|||
|
better performance.
|
|||
|
|
|||
|
|
|||
|
Installation
|
|||
|
==============
|
|||
|
|
|||
|
### CocoaPods
|
|||
|
|
|||
|
1. Add `pod 'YYCache'` to your Podfile.
|
|||
|
2. Run `pod install` or `pod update`.
|
|||
|
3. Import \<YYCache/YYCache.h\>.
|
|||
|
|
|||
|
|
|||
|
### Carthage
|
|||
|
|
|||
|
1. Add `github "ibireme/YYCache"` to your Cartfile.
|
|||
|
2. Run `carthage update --platform ios` and add the framework to your project.
|
|||
|
3. Import \<YYCache/YYCache.h\>.
|
|||
|
|
|||
|
|
|||
|
### Manually
|
|||
|
|
|||
|
1. Download all the files in the YYCache subdirectory.
|
|||
|
2. Add the source files to your Xcode project.
|
|||
|
3. Link with required frameworks:
|
|||
|
* UIKit
|
|||
|
* CoreFoundation
|
|||
|
* QuartzCore
|
|||
|
* sqlite3
|
|||
|
4. Import `YYCache.h`.
|
|||
|
|
|||
|
|
|||
|
Documentation
|
|||
|
==============
|
|||
|
Full API documentation is available on [CocoaDocs](http://cocoadocs.org/docsets/YYCache/).<br/>
|
|||
|
You can also install documentation locally using [appledoc](https://github.com/tomaz/appledoc).
|
|||
|
|
|||
|
|
|||
|
Requirements
|
|||
|
==============
|
|||
|
This library requires `iOS 6.0+` and `Xcode 7.0+`.
|
|||
|
|
|||
|
|
|||
|
License
|
|||
|
==============
|
|||
|
YYCache is provided under the MIT license. See LICENSE file for details.
|
|||
|
|
|||
|
|
|||
|
<br/><br/>
|
|||
|
---
|
|||
|
中文介绍
|
|||
|
==============
|
|||
|
高性能 iOS 缓存框架。<br/>
|
|||
|
(该项目是 [YYKit](https://github.com/ibireme/YYKit) 组件之一)
|
|||
|
|
|||
|
性能
|
|||
|
==============
|
|||
|
|
|||
|
iPhone 6 上,内存缓存每秒响应次数 (越高越好):
|
|||
|
![Memory cache benchmark result](https://raw.github.com/ibireme/YYCache/master/Benchmark/Result_memory.png
|
|||
|
)
|
|||
|
|
|||
|
iPhone 6 上,磁盘缓存每秒响应次数 (越高越好):
|
|||
|
![Disk benchmark result](https://raw.github.com/ibireme/YYCache/master/Benchmark/Result_disk.png
|
|||
|
)
|
|||
|
|
|||
|
推荐到 SQLite 官网[下载](http://www.sqlite.org/download.html)和编译最新的 SQLite,以替换 iOS 自带的 libsqlite3.dylib,以获得最高 1.5~3 倍的性能提升。
|
|||
|
|
|||
|
更多测试代码和用例见 `Benchmark/CacheBenchmark.xcodeproj`。
|
|||
|
|
|||
|
|
|||
|
特性
|
|||
|
==============
|
|||
|
- **LRU**: 缓存支持 LRU (least-recently-used) 淘汰算法。
|
|||
|
- **缓存控制**: 支持多种缓存控制方法:总数量、总大小、存活时间、空闲空间。
|
|||
|
- **兼容性**: API 基本和 `NSCache` 保持一致, 所有方法都是线程安全的。
|
|||
|
- **内存缓存**
|
|||
|
- **对象释放控制**: 对象的释放(release) 可以配置为同步或异步进行,可以配置在主线程或后台线程进行。
|
|||
|
- **自动清空**: 当收到内存警告或 App 进入后台时,缓存可以配置为自动清空。
|
|||
|
- **磁盘缓存**
|
|||
|
- **可定制性**: 磁盘缓存支持自定义的归档解档方法,以支持那些没有实现 NSCoding 协议的对象。
|
|||
|
- **存储类型控制**: 磁盘缓存支持对每个对象的存储类型 (SQLite/文件) 进行自动或手动控制,以获得更高的存取性能。
|
|||
|
|
|||
|
|
|||
|
安装
|
|||
|
==============
|
|||
|
|
|||
|
### CocoaPods
|
|||
|
|
|||
|
1. 在 Podfile 中添加 `pod 'YYCache'`。
|
|||
|
2. 执行 `pod install` 或 `pod update`。
|
|||
|
3. 导入 \<YYCache/YYCache.h\>。
|
|||
|
|
|||
|
|
|||
|
### Carthage
|
|||
|
|
|||
|
1. 在 Cartfile 中添加 `github "ibireme/YYCache"`。
|
|||
|
2. 执行 `carthage update --platform ios` 并将生成的 framework 添加到你的工程。
|
|||
|
3. 导入 \<YYCache/YYCache.h\>。
|
|||
|
|
|||
|
|
|||
|
### 手动安装
|
|||
|
|
|||
|
1. 下载 YYCache 文件夹内的所有内容。
|
|||
|
2. 将 YYCache 内的源文件添加(拖放)到你的工程。
|
|||
|
3. 链接以下的 frameworks:
|
|||
|
* UIKit
|
|||
|
* CoreFoundation
|
|||
|
* QuartzCore
|
|||
|
* sqlite3
|
|||
|
4. 导入 `YYCache.h`。
|
|||
|
|
|||
|
|
|||
|
文档
|
|||
|
==============
|
|||
|
你可以在 [CocoaDocs](http://cocoadocs.org/docsets/YYCache/) 查看在线 API 文档,也可以用 [appledoc](https://github.com/tomaz/appledoc) 本地生成文档。
|
|||
|
|
|||
|
|
|||
|
系统要求
|
|||
|
==============
|
|||
|
该项目最低支持 `iOS 6.0` 和 `Xcode 7.0`。
|
|||
|
|
|||
|
|
|||
|
许可证
|
|||
|
==============
|
|||
|
YYCache 使用 MIT 许可证,详情见 LICENSE 文件。
|
|||
|
|
|||
|
|
|||
|
相关链接
|
|||
|
==============
|
|||
|
[YYCache 设计思路与技术细节](http://blog.ibireme.com/2015/10/26/yycache/)
|
|||
|
|
|||
|
|