commit
29123408b0
@ -0,0 +1,37 @@ |
|||||||
|
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
|
||||||
|
// This source code is licensed under the BSD-style license found in the
|
||||||
|
// LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
// of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
|
||||||
|
package org.rocksdb; |
||||||
|
|
||||||
|
/** |
||||||
|
* 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. |
||||||
|
* |
||||||
|
* Default value of bits per key is 10. |
||||||
|
*/ |
||||||
|
public class BloomFilter extends Filter { |
||||||
|
private static final int DEFAULT_BITS_PER_KEY = 10; |
||||||
|
private final int bitsPerKey_; |
||||||
|
|
||||||
|
public BloomFilter() { |
||||||
|
this(DEFAULT_BITS_PER_KEY); |
||||||
|
} |
||||||
|
|
||||||
|
public BloomFilter(int bitsPerKey) { |
||||||
|
super(); |
||||||
|
bitsPerKey_ = bitsPerKey; |
||||||
|
|
||||||
|
createNewFilter(); |
||||||
|
} |
||||||
|
|
||||||
|
@Override |
||||||
|
protected void createNewFilter() { |
||||||
|
createNewFilter0(bitsPerKey_); |
||||||
|
} |
||||||
|
|
||||||
|
private native void createNewFilter0(int bitsKeyKey); |
||||||
|
} |
@ -0,0 +1,38 @@ |
|||||||
|
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
|
||||||
|
// This source code is licensed under the BSD-style license found in the
|
||||||
|
// LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
// of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
|
||||||
|
package org.rocksdb; |
||||||
|
|
||||||
|
/** |
||||||
|
* Filters are stored in rocksdb and are consulted automatically |
||||||
|
* by rocksdb to decide whether or not to read some |
||||||
|
* information from disk. In many cases, a filter can cut down the |
||||||
|
* number of disk seeks form a handful to a single disk seek per |
||||||
|
* DB::Get() call. |
||||||
|
*/ |
||||||
|
public abstract class Filter { |
||||||
|
protected long nativeHandle_ = 0; |
||||||
|
|
||||||
|
protected abstract void createNewFilter(); |
||||||
|
|
||||||
|
/** |
||||||
|
* Deletes underlying C++ filter pointer. |
||||||
|
*/ |
||||||
|
public synchronized void dispose() { |
||||||
|
if(nativeHandle_ != 0) { |
||||||
|
dispose0(nativeHandle_); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@Override protected void finalize() { |
||||||
|
dispose(); |
||||||
|
} |
||||||
|
|
||||||
|
protected boolean isInitialized() { |
||||||
|
return (nativeHandle_ != 0); |
||||||
|
} |
||||||
|
|
||||||
|
private native void dispose0(long handle); |
||||||
|
} |
@ -0,0 +1,41 @@ |
|||||||
|
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
|
||||||
|
// This source code is licensed under the BSD-style license found in the
|
||||||
|
// LICENSE file in the root directory of this source tree. An additional grant
|
||||||
|
// of patent rights can be found in the PATENTS file in the same directory.
|
||||||
|
//
|
||||||
|
// This file implements the "bridge" between Java and C++ for
|
||||||
|
// rocksdb::FilterPolicy.
|
||||||
|
|
||||||
|
#include <stdio.h> |
||||||
|
#include <stdlib.h> |
||||||
|
#include <jni.h> |
||||||
|
#include <string> |
||||||
|
|
||||||
|
#include "include/org_rocksdb_Filter.h" |
||||||
|
#include "include/org_rocksdb_BloomFilter.h" |
||||||
|
#include "rocksjni/portal.h" |
||||||
|
#include "rocksdb/filter_policy.h" |
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_rocksdb_BloomFilter |
||||||
|
* Method: createNewFilter0 |
||||||
|
* Signature: (I)V |
||||||
|
*/ |
||||||
|
void Java_org_rocksdb_BloomFilter_createNewFilter0( |
||||||
|
JNIEnv* env, jobject jobj, jint bits_per_key) { |
||||||
|
const rocksdb::FilterPolicy* fp = rocksdb::NewBloomFilterPolicy(bits_per_key); |
||||||
|
rocksdb::FilterJni::setHandle(env, jobj, fp); |
||||||
|
} |
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: org_rocksdb_Filter |
||||||
|
* Method: dispose0 |
||||||
|
* Signature: (J)V |
||||||
|
*/ |
||||||
|
void Java_org_rocksdb_Filter_dispose0( |
||||||
|
JNIEnv* env, jobject jobj, jlong handle) { |
||||||
|
auto fp = reinterpret_cast<rocksdb::FilterPolicy*>(handle); |
||||||
|
delete fp; |
||||||
|
|
||||||
|
rocksdb::FilterJni::setHandle(env, jobj, nullptr); |
||||||
|
} |
Loading…
Reference in new issue