Class SimpleCache
- java.lang.Object
-
- com.google.android.exoplayer2.upstream.cache.SimpleCache
-
- All Implemented Interfaces:
Cache
@Deprecated public final class SimpleCache extends Object implements Cache
Deprecated.com.google.android.exoplayer2 is deprecated. Please migrate to androidx.media3 (which contains the same ExoPlayer code). See the migration guide for more details, including a script to help with the migration.ACacheimplementation that maintains an in-memory representation.Only one instance of SimpleCache is allowed for a given directory at a given time.
To delete a SimpleCache, use
delete(File, DatabaseProvider)rather than deleting the directory and its contents directly. This is necessary to ensure that associated index data is also removed.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface com.google.android.exoplayer2.upstream.cache.Cache
Cache.CacheException, Cache.Listener
-
-
Constructor Summary
Constructors Constructor Description SimpleCache(File cacheDir, CacheEvictor evictor)Deprecated.Use a constructor that takes aDatabaseProviderfor improved performance.SimpleCache(File cacheDir, CacheEvictor evictor, DatabaseProvider databaseProvider)Deprecated.Constructs the cache.SimpleCache(File cacheDir, CacheEvictor evictor, DatabaseProvider databaseProvider, byte[] legacyIndexSecretKey, boolean legacyIndexEncrypt, boolean preferLegacyIndex)Deprecated.Constructs the cache.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description NavigableSet<CacheSpan>addListener(String key, Cache.Listener listener)Deprecated.Registers a listener to listen for changes to a given resource.voidapplyContentMetadataMutations(String key, ContentMetadataMutations mutations)Deprecated.Appliesmutationsto theContentMetadatafor the given resource.voidcheckInitialization()Deprecated.Checks whether the cache was initialized successfully.voidcommitFile(File file, long length)Deprecated.Commits a file into the cache.static voiddelete(File cacheDir, DatabaseProvider databaseProvider)Deprecated.Deletes all content belonging to a cache instance.longgetCachedBytes(String key, long position, long length)Deprecated.Returns the total number of cached bytes betweenposition(inclusive) and(position + length)(exclusive) of a resource.longgetCachedLength(String key, long position, long length)Deprecated.Returns the length of continuously cached data starting fromposition, up to a maximum ofmaxLength, of a resource.NavigableSet<CacheSpan>getCachedSpans(String key)Deprecated.Returns the cached spans for a given resource.longgetCacheSpace()Deprecated.Returns the total disk space in bytes used by the cache.ContentMetadatagetContentMetadata(String key)Deprecated.Returns aContentMetadatafor the given resource.Set<String>getKeys()Deprecated.Returns the cache keys of all of the resources that are at least partially cached.longgetUid()Deprecated.Returns a non-negative unique identifier for the cache, orCache.UID_UNSETif initialization failed before the unique identifier was determined.booleanisCached(String key, long position, long length)Deprecated.Returns whether the specified range of data in a resource is fully cached.static booleanisCacheFolderLocked(File cacheFolder)Deprecated.Returns whethercacheFolderis locked by aSimpleCacheinstance.voidrelease()Deprecated.Releases the cache.voidreleaseHoleSpan(CacheSpan holeSpan)Deprecated.Releases aCacheSpanobtained fromCache.startReadWrite(String, long, long)which corresponded to a hole in the cache.voidremoveListener(String key, Cache.Listener listener)Deprecated.Unregisters a listener.voidremoveResource(String key)Deprecated.Removes allCacheSpansfor a resource, deleting the underlying files.voidremoveSpan(CacheSpan span)Deprecated.Removes a cachedCacheSpanfrom the cache, deleting the underlying file.FilestartFile(String key, long position, long length)Deprecated.Obtains a cache file into which data can be written.CacheSpanstartReadWrite(String key, long position, long length)Deprecated.A caller should invoke this method when they require data starting from a given position in a given resource.CacheSpanstartReadWriteNonBlocking(String key, long position, long length)Deprecated.
-
-
-
Constructor Detail
-
SimpleCache
@Deprecated public SimpleCache(File cacheDir, CacheEvictor evictor)
Deprecated.Use a constructor that takes aDatabaseProviderfor improved performance.Constructs the cache. The cache will delete any unrecognized files from the directory. Hence the directory cannot be used to store other files.- Parameters:
cacheDir- A dedicated cache directory.evictor- The evictor to be used. For download use cases where cache eviction should not occur, useNoOpCacheEvictor.
-
SimpleCache
public SimpleCache(File cacheDir, CacheEvictor evictor, DatabaseProvider databaseProvider)
Deprecated.Constructs the cache. The cache will delete any unrecognized files from the directory. Hence the directory cannot be used to store other files.- Parameters:
cacheDir- A dedicated cache directory.evictor- The evictor to be used. For download use cases where cache eviction should not occur, useNoOpCacheEvictor.databaseProvider- Provides the database in which the cache index is stored.
-
SimpleCache
public SimpleCache(File cacheDir, CacheEvictor evictor, @Nullable DatabaseProvider databaseProvider, @Nullable byte[] legacyIndexSecretKey, boolean legacyIndexEncrypt, boolean preferLegacyIndex)
Deprecated.Constructs the cache. The cache will delete any unrecognized files from the cache directory. Hence the directory cannot be used to store other files.- Parameters:
cacheDir- A dedicated cache directory.evictor- The evictor to be used. For download use cases where cache eviction should not occur, useNoOpCacheEvictor.databaseProvider- Provides the database in which the cache index is stored, ornullto use a legacy index. Using a database index is highly recommended for performance reasons.legacyIndexSecretKey- A 16 byte AES key for reading, and optionally writing, the legacy index. Not used by the database index, however should still be provided when using the database index in cases where upgrading from the legacy index may be necessary.legacyIndexEncrypt- Whether to encrypt when writing to the legacy index. Must befalseiflegacyIndexSecretKeyisnull. Not used by the database index.preferLegacyIndex- Whether to use the legacy index even if adatabaseProvideris provided. Should befalsein nearly all cases. Setting this totrueis only useful for downgrading from the database index back to the legacy index.
-
-
Method Detail
-
isCacheFolderLocked
public static boolean isCacheFolderLocked(File cacheFolder)
Deprecated.Returns whethercacheFolderis locked by aSimpleCacheinstance. To unlock the folder theSimpleCacheinstance should be released.
-
delete
@WorkerThread public static void delete(File cacheDir, @Nullable DatabaseProvider databaseProvider)
Deprecated.Deletes all content belonging to a cache instance.This method may be slow and shouldn't normally be called on the main thread.
- Parameters:
cacheDir- The cache directory.databaseProvider- The database in which index data is stored, ornullif the cache used a legacy index.
-
checkInitialization
public void checkInitialization() throws Cache.CacheExceptionDeprecated.Checks whether the cache was initialized successfully.- Throws:
Cache.CacheException- If an error occurred during initialization.
-
getUid
public long getUid()
Deprecated.Description copied from interface:CacheReturns a non-negative unique identifier for the cache, orCache.UID_UNSETif initialization failed before the unique identifier was determined.Implementations are expected to generate and store the unique identifier alongside the cached content. If the location of the cache is deleted or swapped, it is expected that a new unique identifier will be generated when the cache is recreated.
-
release
public void release()
Deprecated.Description copied from interface:CacheReleases the cache. This method must be called when the cache is no longer required. The cache must not be used after calling this method.This method may be slow and shouldn't normally be called on the main thread.
-
addListener
public NavigableSet<CacheSpan> addListener(String key, Cache.Listener listener)
Deprecated.Description copied from interface:CacheRegisters a listener to listen for changes to a given resource.No guarantees are made about the thread or threads on which the listener is called, but it is guaranteed that listener methods will be called in a serial fashion (i.e. one at a time) and in the same order as events occurred.
- Specified by:
addListenerin interfaceCache- Parameters:
key- The cache key of the resource.listener- The listener to add.- Returns:
- The current spans for the resource.
-
removeListener
public void removeListener(String key, Cache.Listener listener)
Deprecated.Description copied from interface:CacheUnregisters a listener.- Specified by:
removeListenerin interfaceCache- Parameters:
key- The cache key of the resource.listener- The listener to remove.
-
getCachedSpans
public NavigableSet<CacheSpan> getCachedSpans(String key)
Deprecated.Description copied from interface:CacheReturns the cached spans for a given resource.- Specified by:
getCachedSpansin interfaceCache- Parameters:
key- The cache key of the resource.- Returns:
- The spans for the key.
-
getKeys
public Set<String> getKeys()
Deprecated.Description copied from interface:CacheReturns the cache keys of all of the resources that are at least partially cached.
-
getCacheSpace
public long getCacheSpace()
Deprecated.Description copied from interface:CacheReturns the total disk space in bytes used by the cache.- Specified by:
getCacheSpacein interfaceCache
-
startReadWrite
public CacheSpan startReadWrite(String key, long position, long length) throws InterruptedException, Cache.CacheException
Deprecated.Description copied from interface:CacheA caller should invoke this method when they require data starting from a given position in a given resource.If there is a cache entry that overlaps the position, then the returned
CacheSpandefines the file in which the data is stored.CacheSpan.isCachedis true. The caller may read from the cache file, but does not acquire any locks.If there is no cache entry overlapping
position, then the returnedCacheSpandefines a hole in the cache starting atpositioninto which the caller may write as it obtains the data from some other source. The returnedCacheSpanserves as a lock. Whilst the caller holds the lock it may write data into the hole. It may split data into multiple files. When the caller has finished writing a file it should commit it to the cache by callingCache.commitFile(File, long). When the caller has finished writing, it must release the lock by callingCache.releaseHoleSpan(com.google.android.exoplayer2.upstream.cache.CacheSpan).This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
startReadWritein interfaceCache- Parameters:
key- The cache key of the resource.position- The starting position in the resource from which data is required.length- The length of the data being requested, orC.LENGTH_UNSETif unbounded. The length is ignored if there is a cache entry that overlaps the position. Else, it defines the maximum length of the holeCacheSpanthat's returned. Cache implementations may support parallel writes into non-overlapping holes, and so passing the actual required length should be preferred to passingC.LENGTH_UNSETwhen possible.- Returns:
- The
CacheSpan. - Throws:
InterruptedException- If the thread was interrupted.Cache.CacheException- If an error is encountered.
-
startReadWriteNonBlocking
@Nullable public CacheSpan startReadWriteNonBlocking(String key, long position, long length) throws Cache.CacheException
Deprecated.Description copied from interface:CacheSame asCache.startReadWrite(String, long, long). However, if the cache entry is locked, then instead of blocking, this method will return null as theCacheSpan.This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
startReadWriteNonBlockingin interfaceCache- Parameters:
key- The cache key of the resource.position- The starting position in the resource from which data is required.length- The length of the data being requested, orC.LENGTH_UNSETif unbounded. The length is ignored if there is a cache entry that overlaps the position. Else, it defines the range of data locked by the returnedCacheSpan.- Returns:
- The
CacheSpan. Or null if the cache entry is locked. - Throws:
Cache.CacheException- If an error is encountered.
-
startFile
public File startFile(String key, long position, long length) throws Cache.CacheException
Deprecated.Description copied from interface:CacheObtains a cache file into which data can be written. Must only be called when holding a corresponding holeCacheSpanobtained fromCache.startReadWrite(String, long, long).This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
startFilein interfaceCache- Parameters:
key- The cache key of the resource being written.position- The starting position in the resource from which data will be written.length- The length of the data being written, orC.LENGTH_UNSETif unknown. Used only to ensure that there is enough space in the cache.- Returns:
- The file into which data should be written.
- Throws:
Cache.CacheException- If an error is encountered.
-
commitFile
public void commitFile(File file, long length) throws Cache.CacheException
Deprecated.Description copied from interface:CacheCommits a file into the cache. Must only be called when holding a corresponding holeCacheSpanobtained fromCache.startReadWrite(String, long, long).This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
commitFilein interfaceCache- Parameters:
file- A newly written cache file.length- The length of the newly written cache file in bytes.- Throws:
Cache.CacheException- If an error is encountered.
-
releaseHoleSpan
public void releaseHoleSpan(CacheSpan holeSpan)
Deprecated.Description copied from interface:CacheReleases aCacheSpanobtained fromCache.startReadWrite(String, long, long)which corresponded to a hole in the cache.- Specified by:
releaseHoleSpanin interfaceCache- Parameters:
holeSpan- TheCacheSpanbeing released.
-
removeResource
public void removeResource(String key)
Deprecated.Description copied from interface:CacheRemoves allCacheSpansfor a resource, deleting the underlying files.- Specified by:
removeResourcein interfaceCache- Parameters:
key- The cache key of the resource being removed.
-
removeSpan
public void removeSpan(CacheSpan span)
Deprecated.Description copied from interface:CacheRemoves a cachedCacheSpanfrom the cache, deleting the underlying file.This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
removeSpanin interfaceCache- Parameters:
span- TheCacheSpanto remove.
-
isCached
public boolean isCached(String key, long position, long length)
Deprecated.Description copied from interface:CacheReturns whether the specified range of data in a resource is fully cached.
-
getCachedLength
public long getCachedLength(String key, long position, long length)
Deprecated.Description copied from interface:CacheReturns the length of continuously cached data starting fromposition, up to a maximum ofmaxLength, of a resource. Ifpositionisn't cached then-holeLengthis returned, whereholeLengthis the length of continuously uncached data starting fromposition, up to a maximum ofmaxLength.- Specified by:
getCachedLengthin interfaceCache- Parameters:
key- The cache key of the resource.position- The starting position of the data in the resource.length- The maximum length of the data or hole to be returned.C.LENGTH_UNSETis permitted, and is equivalent to passingLong.MAX_VALUE.- Returns:
- The length of the continuously cached data, or
-holeLengthifpositionisn't cached.
-
getCachedBytes
public long getCachedBytes(String key, long position, long length)
Deprecated.Description copied from interface:CacheReturns the total number of cached bytes betweenposition(inclusive) and(position + length)(exclusive) of a resource.- Specified by:
getCachedBytesin interfaceCache- Parameters:
key- The cache key of the resource.position- The starting position of the data in the resource.length- The length of the data to check.C.LENGTH_UNSETis permitted, and is equivalent to passingLong.MAX_VALUE.- Returns:
- The total number of cached bytes.
-
applyContentMetadataMutations
public void applyContentMetadataMutations(String key, ContentMetadataMutations mutations) throws Cache.CacheException
Deprecated.Description copied from interface:CacheAppliesmutationsto theContentMetadatafor the given resource. A newCachedContentis added if there isn't one already for the resource.This method may be slow and shouldn't normally be called on the main thread.
- Specified by:
applyContentMetadataMutationsin interfaceCache- Parameters:
key- The cache key of the resource.mutations- Contains mutations to be applied to the metadata.- Throws:
Cache.CacheException- If an error is encountered.
-
getContentMetadata
public ContentMetadata getContentMetadata(String key)
Deprecated.Description copied from interface:CacheReturns aContentMetadatafor the given resource.- Specified by:
getContentMetadatain interfaceCache- Parameters:
key- The cache key of the resource.- Returns:
- The
ContentMetadatafor the resource.
-
-