Skip to content

3.0: Sync by default

Compare
Choose a tag to compare
@aschuch aschuch released this 03 Jun 15:56
· 24 commits to master since this release

AwesomeCache 3 is designed to have a sync API, making it easy to reason about the actual contents of the cache. This decision has been made based on feedback from the community, to keep the API of AwesomeCache small and easy to use.

The internals of the cache use a concurrent dispatch queue, that syncs reads and writes for thread safety. In case a particular caching operation blocks your main thread for too long, consider offloading the read and write operations to a different thread.

dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)) {
    cache["name"] = "Alex"
}

Further improvements

  • Added a new way to return an expired object in objectForKey: if present (#31)
  • Adds a way to set the NSFileProtectionKey value on the internal NSFileManager. This may be necessary in case you observe odd behaviour when accessing the cache in the background. (#64)
  • Adds a new method to get allObjects from the cache (optionally, expired objects may be queried as well)