Refactor filter impl

This commit is contained in:
Ankit Gupta 2014-04-22 00:04:56 -07:00
parent 5e797cf0dd
commit 677b0d6d3f
4 changed files with 11 additions and 15 deletions

View File

@ -12,22 +12,18 @@ package org.rocksdb;
* number of disk seeks form a handful to a single disk seek per
* DB::Get() call.
*
* This function a new filter policy that uses a bloom filter
* This class creates a new filter policy that uses a bloom filter
* with approximately the specified number of bits per key.
* A good value for bitsPerKey is 10, which yields a filter
* with ~ 1% false positive rate.
* with ~ 1% false positive rate.
*/
public class Filter {
private long nativeHandle_;
public Filter(int bitsPerKey) {
newFilter(bitsPerKey);
}
public long getNativeHandle() {
return nativeHandle_;
}
/**
* Deletes underlying C++ filter pointer.
*/
@ -44,7 +40,7 @@ public class Filter {
private boolean isInitialized() {
return (nativeHandle_ != 0);
}
private native void newFilter(int bitsPerKey);
private native void dispose0(long handle);
}
}

View File

@ -152,7 +152,7 @@ public class Options {
*/
public Options setFilter(Filter filter) {
assert(isInitialized());
setFilter0(nativeHandle_, filter.getNativeHandle());
setFilter0(nativeHandle_, filter);
return this;
}
@ -1250,7 +1250,7 @@ public class Options {
private native void useFixedLengthPrefixExtractor(
long handle, int prefixLength);
private native void setFilter0(long optHandle, long fpHandle);
private native void setFilter0(long optHandle, Filter fp);
long nativeHandle_;
long cacheSize_;

View File

@ -36,4 +36,4 @@ void Java_org_rocksdb_Filter_dispose0(
delete fp;
rocksdb::FilterJni::setHandle(env, jobj, nullptr);
}
}

View File

@ -126,9 +126,9 @@ jlong Java_org_rocksdb_Options_statisticsPtr(
* Signature: (JJ)V
*/
void Java_org_rocksdb_Options_setFilter0(
JNIEnv* env, jobject jobj, jlong jopt_handle, jlong jfp_handle) {
JNIEnv* env, jobject jobj, jlong jopt_handle, jobject jfp) {
reinterpret_cast<rocksdb::Options*>(jopt_handle)->filter_policy =
reinterpret_cast<rocksdb::FilterPolicy*>(jfp_handle);
rocksdb::FilterJni::getHandle(env, jfp);
}
/*