Package org.redisson.api
Interface RBloomFilter<T>
- Type Parameters:
T- - type of object
- All Superinterfaces:
RExpirable,RExpirableAsync,RObject,RObjectAsync
- All Known Implementing Classes:
RedissonBloomFilter
Distributed implementation of Bloom filter based on Highway 128-bit hash.
- Author:
- Nikita Koksharov
-
Method Summary
Modifier and TypeMethodDescriptionbooleanAdds elementbooleanCheck for element presentlongcount()Calculates probabilistic number of elements already added to Bloom filter.longReturns expected amount of insertions per element.doubleReturns false probability of element presence.intReturns hash iterations amount used per element.longgetSize()Returns number of bits in Redis memory required by this instancebooleantryInit(long expectedInsertions, double falseProbability) Initializes Bloom filter params (size and hashIterations) calculated fromexpectedInsertionsandfalseProbabilityStores config to Redis server.Methods inherited from interface org.redisson.api.RExpirable
clearExpire, expire, expire, expire, expireAt, expireAt, expireIfGreater, expireIfGreater, expireIfLess, expireIfLess, expireIfNotSet, expireIfNotSet, expireIfSet, expireIfSet, getExpireTime, remainTimeToLiveMethods inherited from interface org.redisson.api.RExpirableAsync
clearExpireAsync, expireAsync, expireAsync, expireAsync, expireAtAsync, expireAtAsync, expireIfGreaterAsync, expireIfGreaterAsync, expireIfLessAsync, expireIfLessAsync, expireIfNotSetAsync, expireIfNotSetAsync, expireIfSetAsync, expireIfSetAsync, getExpireTimeAsync, remainTimeToLiveAsyncMethods inherited from interface org.redisson.api.RObject
addListener, copy, delete, dump, getCodec, getIdleTime, getName, isExists, migrate, move, removeListener, rename, renamenx, restore, restore, restoreAndReplace, restoreAndReplace, sizeInMemory, touch, unlinkMethods inherited from interface org.redisson.api.RObjectAsync
addListenerAsync, copyAsync, deleteAsync, dumpAsync, getIdleTimeAsync, isExistsAsync, migrateAsync, moveAsync, removeListenerAsync, renameAsync, renamenxAsync, restoreAndReplaceAsync, restoreAndReplaceAsync, restoreAsync, restoreAsync, sizeInMemoryAsync, touchAsync, unlinkAsync
-
Method Details
-
add
Adds element- Parameters:
object- - element to add- Returns:
trueif element has been added successfullyfalseif element is already present
-
contains
Check for element present- Parameters:
object- - element- Returns:
trueif element is presentfalseif element is not present
-
tryInit
boolean tryInit(long expectedInsertions, double falseProbability) Initializes Bloom filter params (size and hashIterations) calculated fromexpectedInsertionsandfalseProbabilityStores config to Redis server.- Parameters:
expectedInsertions- - expected amount of insertions per elementfalseProbability- - expected false probability- Returns:
trueif Bloom filter initializedfalseif Bloom filter already has been initialized
-
getExpectedInsertions
long getExpectedInsertions()Returns expected amount of insertions per element. Calculated during bloom filter initialization.- Returns:
- expected amount of insertions per element
-
getFalseProbability
double getFalseProbability()Returns false probability of element presence. Calculated during bloom filter initialization.- Returns:
- false probability of element presence
-
getSize
long getSize()Returns number of bits in Redis memory required by this instance- Returns:
- number of bits
-
getHashIterations
int getHashIterations()Returns hash iterations amount used per element. Calculated during bloom filter initialization.- Returns:
- hash iterations amount
-
count
long count()Calculates probabilistic number of elements already added to Bloom filter.- Returns:
- probabilistic number of elements
-