Read Options to support direct slice (#7132)

Summary:
This request is adding support for using DirectSlice in ReadOptions lower/upper bounds.

To be more efficient I have added setLength to DirectSlice so I can just update the length to be used by slice from direct buffer. It is also needed, because when one creates iterator it keep pointer to original slice so setting new slice in options does not help (it needs to reuse existing one). Using this approach one can modify the slice any time during operations with iterator.

Pull Request resolved: https://github.com/facebook/rocksdb/pull/7132

Reviewed By: zhichao-cao

Differential Revision: D25840092

Pulled By: jay-zhuang

fbshipit-source-id: 760167baf61568c9a35138145c4bf9b06824cb71
main
Tomas Kolda 4 years ago committed by Facebook GitHub Bot
parent 2fb6d9337f
commit 1001bc01c9
  1. 11
      java/rocksjni/slice.cc
  2. 5
      java/src/main/java/org/rocksdb/DirectSlice.java
  3. 18
      java/src/main/java/org/rocksdb/ReadOptions.java
  4. 4
      java/src/test/java/org/rocksdb/ReadOptionsTest.java

@ -228,6 +228,17 @@ void Java_org_rocksdb_Slice_removePrefix0(JNIEnv* /*env*/, jobject /*jobj*/,
slice->remove_prefix(length); slice->remove_prefix(length);
} }
/*
* Class: org_rocksdb_DirectSlice
* Method: setLength0
* Signature: (JI)V
*/
void Java_org_rocksdb_DirectSlice_setLength0(JNIEnv* /*env*/, jobject /*jobj*/,
jlong handle, jint length) {
auto* slice = reinterpret_cast<rocksdb::Slice*>(handle);
slice->size_ = length;
}
/* /*
* Class: org_rocksdb_Slice * Class: org_rocksdb_Slice
* Method: disposeInternalBuf * Method: disposeInternalBuf

@ -110,6 +110,10 @@ public class DirectSlice extends AbstractSlice<ByteBuffer> {
this.internalBufferOffset += n; this.internalBufferOffset += n;
} }
public void setLength(final int n) {
setLength0(getNativeHandle(), n);
}
@Override @Override
protected void disposeInternal() { protected void disposeInternal() {
final long nativeHandle = getNativeHandle(); final long nativeHandle = getNativeHandle();
@ -127,6 +131,7 @@ public class DirectSlice extends AbstractSlice<ByteBuffer> {
private native void clear0(long handle, boolean internalBuffer, private native void clear0(long handle, boolean internalBuffer,
long internalBufferOffset); long internalBufferOffset);
private native void removePrefix0(long handle, int length); private native void removePrefix0(long handle, int length);
private native void setLength0(long handle, int length);
private native void disposeInternalBuf(final long handle, private native void disposeInternalBuf(final long handle,
long internalBufferOffset); long internalBufferOffset);
} }

@ -440,13 +440,12 @@ public class ReadOptions extends RocksObject {
* @param iterateLowerBound Slice representing the upper bound * @param iterateLowerBound Slice representing the upper bound
* @return the reference to the current ReadOptions. * @return the reference to the current ReadOptions.
*/ */
public ReadOptions setIterateLowerBound(final Slice iterateLowerBound) { public ReadOptions setIterateLowerBound(final AbstractSlice<?> iterateLowerBound) {
assert(isOwningHandle()); assert(isOwningHandle());
if (iterateLowerBound != null) { setIterateLowerBound(
nativeHandle_, iterateLowerBound == null ? 0 : iterateLowerBound.getNativeHandle());
// Hold onto a reference so it doesn't get garbage collected out from under us. // Hold onto a reference so it doesn't get garbage collected out from under us.
iterateLowerBoundSlice_ = iterateLowerBound; iterateLowerBoundSlice_ = iterateLowerBound;
setIterateLowerBound(nativeHandle_, iterateLowerBoundSlice_.getNativeHandle());
}
return this; return this;
} }
@ -485,13 +484,12 @@ public class ReadOptions extends RocksObject {
* @param iterateUpperBound Slice representing the upper bound * @param iterateUpperBound Slice representing the upper bound
* @return the reference to the current ReadOptions. * @return the reference to the current ReadOptions.
*/ */
public ReadOptions setIterateUpperBound(final Slice iterateUpperBound) { public ReadOptions setIterateUpperBound(final AbstractSlice<?> iterateUpperBound) {
assert(isOwningHandle()); assert(isOwningHandle());
if (iterateUpperBound != null) { setIterateUpperBound(
nativeHandle_, iterateUpperBound == null ? 0 : iterateUpperBound.getNativeHandle());
// Hold onto a reference so it doesn't get garbage collected out from under us. // Hold onto a reference so it doesn't get garbage collected out from under us.
iterateUpperBoundSlice_ = iterateUpperBound; iterateUpperBoundSlice_ = iterateUpperBound;
setIterateUpperBound(nativeHandle_, iterateUpperBoundSlice_.getNativeHandle());
}
return this; return this;
} }
@ -570,8 +568,8 @@ public class ReadOptions extends RocksObject {
// freely leave scope without us losing the Java Slice object, which during // freely leave scope without us losing the Java Slice object, which during
// close() would also reap its associated rocksdb::Slice native object since // close() would also reap its associated rocksdb::Slice native object since
// it's possibly (likely) to be an owning handle. // it's possibly (likely) to be an owning handle.
private Slice iterateLowerBoundSlice_; private AbstractSlice<?> iterateLowerBoundSlice_;
private Slice iterateUpperBoundSlice_; private AbstractSlice<?> iterateUpperBoundSlice_;
private native static long newReadOptions(); private native static long newReadOptions();
private native static long newReadOptions(final boolean verifyChecksums, private native static long newReadOptions(final boolean verifyChecksums,

@ -159,6 +159,8 @@ public class ReadOptionsTest {
Slice upperBound = buildRandomSlice(); Slice upperBound = buildRandomSlice();
opt.setIterateUpperBound(upperBound); opt.setIterateUpperBound(upperBound);
assertThat(Arrays.equals(upperBound.data(), opt.iterateUpperBound().data())).isTrue(); assertThat(Arrays.equals(upperBound.data(), opt.iterateUpperBound().data())).isTrue();
opt.setIterateUpperBound(null);
assertThat(opt.iterateUpperBound()).isNull();
} }
} }
@ -175,6 +177,8 @@ public class ReadOptionsTest {
Slice lowerBound = buildRandomSlice(); Slice lowerBound = buildRandomSlice();
opt.setIterateLowerBound(lowerBound); opt.setIterateLowerBound(lowerBound);
assertThat(Arrays.equals(lowerBound.data(), opt.iterateLowerBound().data())).isTrue(); assertThat(Arrays.equals(lowerBound.data(), opt.iterateLowerBound().data())).isTrue();
opt.setIterateLowerBound(null);
assertThat(opt.iterateLowerBound()).isNull();
} }
} }

Loading…
Cancel
Save