Methods Summary |
---|
public long | address()
return address;
|
public java.nio.IntBuffer | asReadOnlyBuffer()
return new DirectIntBufferRS(this,
this.markValue(),
this.position(),
this.limit(),
this.capacity(),
0);
|
public sun.misc.Cleaner | cleaner() return null;
|
public java.nio.IntBuffer | compact()
int pos = position();
int lim = limit();
assert (pos <= lim);
int rem = (pos <= lim ? lim - pos : 0);
unsafe.copyMemory(ix(pos), ix(0), rem << 2);
position(rem);
limit(capacity());
return this;
|
public java.nio.IntBuffer | duplicate()
return new DirectIntBufferS(this,
this.markValue(),
this.position(),
this.limit(),
this.capacity(),
0);
|
public int | get(int i)
return (Bits.swap(unsafe.getInt(ix(checkIndex(i)))));
|
public java.nio.IntBuffer | get(int[] dst, int offset, int length)
if ((length << 2) > Bits.JNI_COPY_TO_ARRAY_THRESHOLD) {
checkBounds(offset, length, dst.length);
int pos = position();
int lim = limit();
assert (pos <= lim);
int rem = (pos <= lim ? lim - pos : 0);
if (length > rem)
throw new BufferUnderflowException();
if (order() != ByteOrder.nativeOrder())
Bits.copyToIntArray(ix(pos), dst,
offset << 2,
length << 2);
else
Bits.copyToByteArray(ix(pos), dst,
offset << 2,
length << 2);
position(pos + length);
} else {
super.get(dst, offset, length);
}
return this;
|
public int | get()
return (Bits.swap(unsafe.getInt(ix(nextGetIndex()))));
|
public boolean | isDirect()
return true;
|
public boolean | isReadOnly()
return false;
|
private long | ix(int i)
return address + (i << 2);
|
public java.nio.ByteOrder | order()
return ((ByteOrder.nativeOrder() == ByteOrder.BIG_ENDIAN)
? ByteOrder.LITTLE_ENDIAN : ByteOrder.BIG_ENDIAN);
|
public java.nio.IntBuffer | put(int x)
unsafe.putInt(ix(nextPutIndex()), Bits.swap((x)));
return this;
|
public java.nio.IntBuffer | put(int i, int x)
unsafe.putInt(ix(checkIndex(i)), Bits.swap((x)));
return this;
|
public java.nio.IntBuffer | put(java.nio.IntBuffer src)
if (src instanceof DirectIntBufferS) {
if (src == this)
throw new IllegalArgumentException();
DirectIntBufferS sb = (DirectIntBufferS)src;
int spos = sb.position();
int slim = sb.limit();
assert (spos <= slim);
int srem = (spos <= slim ? slim - spos : 0);
int pos = position();
int lim = limit();
assert (pos <= lim);
int rem = (pos <= lim ? lim - pos : 0);
if (srem > rem)
throw new BufferOverflowException();
unsafe.copyMemory(sb.ix(spos), ix(pos), srem << 2);
sb.position(spos + srem);
position(pos + srem);
} else if (!src.isDirect()) {
int spos = src.position();
int slim = src.limit();
assert (spos <= slim);
int srem = (spos <= slim ? slim - spos : 0);
put(src.hb, src.offset + spos, srem);
src.position(spos + srem);
} else {
super.put(src);
}
return this;
|
public java.nio.IntBuffer | put(int[] src, int offset, int length)
if ((length << 2) > Bits.JNI_COPY_FROM_ARRAY_THRESHOLD) {
checkBounds(offset, length, src.length);
int pos = position();
int lim = limit();
assert (pos <= lim);
int rem = (pos <= lim ? lim - pos : 0);
if (length > rem)
throw new BufferOverflowException();
if (order() != ByteOrder.nativeOrder())
Bits.copyFromIntArray(src, offset << 2,
ix(pos), length << 2);
else
Bits.copyFromByteArray(src, offset << 2,
ix(pos), length << 2);
position(pos + length);
} else {
super.put(src, offset, length);
}
return this;
|
public java.nio.IntBuffer | slice()
int pos = this.position();
int lim = this.limit();
assert (pos <= lim);
int rem = (pos <= lim ? lim - pos : 0);
int off = (pos << 2);
assert (off >= 0);
return new DirectIntBufferS(this, -1, 0, rem, rem, off);
|
public java.lang.Object | viewedBuffer()
return viewedBuffer;
|