net.tsz.afinal.bitmap.core
类 LruDiskCache

java.lang.Object
  继承者 net.tsz.afinal.bitmap.core.LruDiskCache
所有已实现的接口:
java.io.Closeable

public final class LruDiskCache
extends java.lang.Object
implements java.io.Closeable

A cache that uses a bounded amount of space on a filesystem. Each cache entry has a string key and a fixed number of values. Values are byte sequences, accessible as streams or files. Each value must be between 0 and Integer.MAX_VALUE bytes in length.

The cache stores its data in a directory on the filesystem. This directory must be exclusive to the cache; the cache may delete or overwrite files from its directory. It is an error for multiple processes to use the same cache directory at the same time.

This cache limits the number of bytes that it will store on the filesystem. When the number of stored bytes exceeds the limit, the cache will remove entries in the background until the limit is satisfied. The limit is not strict: the cache may temporarily exceed it while waiting for files to be deleted. The limit does not include filesystem overhead or the cache journal so space-sensitive applications should set a conservative limit.

Clients call edit(java.lang.String) to create or update the values of an entry. An entry may have only one editor at one time; if a value is not available to be edited then edit(java.lang.String) will return null.

Every edit(java.lang.String) call must be matched by a call to LruDiskCache.Editor.commit() or LruDiskCache.Editor.abort(). Committing is atomic: a read observes the full set of values as they were before or after the commit, but never a mix of values.

Clients call get(java.lang.String) to read a snapshot of an entry. The read will observe the value at the time that get(java.lang.String) was called. Updates and removals after the call do not impact ongoing reads.

This class is tolerant of some I/O errors. If files are missing from the filesystem, the corresponding entries will be dropped from the cache. If an error occurs while writing a cache value, the edit will fail silently. Callers should handle other problems by catching IOException and responding appropriately.


嵌套类摘要
 class LruDiskCache.Editor
          Edits the values for an entry.
 class LruDiskCache.Snapshot
          A snapshot of the values for an entry.
 
方法摘要
 void close()
          Closes this cache.
static void closeQuietly(java.io.Closeable closeable)
          Closes 'closeable', ignoring any checked exceptions.
 void delete()
          Closes the cache and deletes all of its stored values.
static void deleteContents(java.io.File dir)
          Recursively delete everything in dir.
 LruDiskCache.Editor edit(java.lang.String key)
          Returns an editor for the entry named key, or null if another edit is in progress.
 void flush()
          Force buffered operations to the filesystem.
 LruDiskCache.Snapshot get(java.lang.String key)
          Returns a snapshot of the entry named key, or null if it doesn't exist is not currently readable.
 java.io.File getDirectory()
          Returns the directory where this cache stores its data.
 boolean isClosed()
          Returns true if this cache has been closed.
 long maxSize()
          Returns the maximum number of bytes that this cache should use to store its data.
static LruDiskCache open(java.io.File directory, int appVersion, int valueCount, long maxSize)
          Opens the cache in directory, creating a cache if none exists there.
static java.lang.String readAsciiLine(java.io.InputStream in)
          Returns the ASCII characters up to but not including the next "\r\n", or "\n".
static java.lang.String readFully(java.io.Reader reader)
          Returns the remainder of 'reader' as a string, closing it when done.
 boolean remove(java.lang.String key)
          Drops the entry for key if it exists and can be removed.
 long size()
          Returns the number of bytes currently being used to store the values in this cache.
 
从类 java.lang.Object 继承的方法
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

方法详细信息

readFully

public static java.lang.String readFully(java.io.Reader reader)
                                  throws java.io.IOException
Returns the remainder of 'reader' as a string, closing it when done.

抛出:
java.io.IOException

readAsciiLine

public static java.lang.String readAsciiLine(java.io.InputStream in)
                                      throws java.io.IOException
Returns the ASCII characters up to but not including the next "\r\n", or "\n".

抛出:
java.io.EOFException - if the stream is exhausted before the next newline character.
java.io.IOException

closeQuietly

public static void closeQuietly(java.io.Closeable closeable)
Closes 'closeable', ignoring any checked exceptions. Does nothing if 'closeable' is null.


deleteContents

public static void deleteContents(java.io.File dir)
                           throws java.io.IOException
Recursively delete everything in dir.

抛出:
java.io.IOException

open

public static LruDiskCache open(java.io.File directory,
                                int appVersion,
                                int valueCount,
                                long maxSize)
                         throws java.io.IOException
Opens the cache in directory, creating a cache if none exists there.

参数:
directory - a writable directory
appVersion -
valueCount - the number of values per cache entry. Must be positive.
maxSize - the maximum number of bytes this cache should use to store
抛出:
java.io.IOException - if reading or writing the cache directory fails

get

public LruDiskCache.Snapshot get(java.lang.String key)
                          throws java.io.IOException
Returns a snapshot of the entry named key, or null if it doesn't exist is not currently readable. If a value is returned, it is moved to the head of the LRU queue.

抛出:
java.io.IOException

edit

public LruDiskCache.Editor edit(java.lang.String key)
                         throws java.io.IOException
Returns an editor for the entry named key, or null if another edit is in progress.

抛出:
java.io.IOException

getDirectory

public java.io.File getDirectory()
Returns the directory where this cache stores its data.


maxSize

public long maxSize()
Returns the maximum number of bytes that this cache should use to store its data.


size

public long size()
Returns the number of bytes currently being used to store the values in this cache. This may be greater than the max size if a background deletion is pending.


remove

public boolean remove(java.lang.String key)
               throws java.io.IOException
Drops the entry for key if it exists and can be removed. Entries actively being edited cannot be removed.

返回:
true if an entry was removed.
抛出:
java.io.IOException

isClosed

public boolean isClosed()
Returns true if this cache has been closed.


flush

public void flush()
           throws java.io.IOException
Force buffered operations to the filesystem.

抛出:
java.io.IOException

close

public void close()
           throws java.io.IOException
Closes this cache. Stored values will remain on the filesystem.

指定者:
接口 java.io.Closeable 中的 close
抛出:
java.io.IOException

delete

public void delete()
            throws java.io.IOException
Closes the cache and deletes all of its stored values. This will delete all files in the cache directory including files that weren't created by the cache.

抛出:
java.io.IOException