mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
6e7149061c
The main idea is to make DatagramChannel and *SocketChannel behave in a way that more closely matches the standard, e.g. allow binding sockets to addresses without necessarily listening on those addresses and accept null addresses where appropriate. It also avoids multiple redundant DNS lookups. This commit also implements CharBuffer and BindException, and adds the Readable interface.
140 lines
3.2 KiB
Java
140 lines
3.2 KiB
Java
import java.nio.ByteBuffer;
|
|
import java.nio.BufferUnderflowException;
|
|
import java.nio.BufferOverflowException;
|
|
|
|
public class Buffers {
|
|
static {
|
|
System.loadLibrary("test");
|
|
}
|
|
|
|
private static void expect(boolean v) {
|
|
if (! v) throw new RuntimeException();
|
|
}
|
|
|
|
private static void test(Factory factory1, Factory factory2) {
|
|
{ final int size = 64;
|
|
ByteBuffer b1 = factory1.allocate(size);
|
|
try {
|
|
for (int i = 0; i < size; ++i)
|
|
b1.put(i, (byte) 42);
|
|
|
|
for (int i = 0; i < size; ++i)
|
|
expect(b1.get(i) == 42);
|
|
|
|
for (int i = 0; i < size / 2; ++i)
|
|
b1.putShort(i * 2, (short) -12345);
|
|
|
|
for (int i = 0; i < size / 2; ++i)
|
|
expect(b1.getShort(i * 2) == -12345);
|
|
|
|
for (int i = 0; i < size / 4; ++i)
|
|
b1.putInt(i * 4, 0x12345678);
|
|
|
|
for (int i = 0; i < size / 4; ++i)
|
|
expect(b1.getInt(i * 4) == 0x12345678);
|
|
|
|
for (int i = 0; i < size / 8; ++i)
|
|
b1.putLong(i * 8, 0x1234567890ABCDEFL);
|
|
|
|
for (int i = 0; i < size / 8; ++i)
|
|
expect(b1.getLong(i * 8) == 0x1234567890ABCDEFL);
|
|
|
|
ByteBuffer b2 = factory2.allocate(size);
|
|
try {
|
|
b2.put(b1);
|
|
|
|
for (int i = 0; i < size / 8; ++i)
|
|
expect(b2.getLong(i * 8) == 0x1234567890ABCDEFL);
|
|
|
|
} finally {
|
|
factory2.dispose(b2);
|
|
}
|
|
} finally {
|
|
factory1.dispose(b1);
|
|
}
|
|
}
|
|
}
|
|
|
|
private static native ByteBuffer allocateNative(int capacity);
|
|
|
|
private static native void freeNative(ByteBuffer b);
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
Factory array = new Factory() {
|
|
public ByteBuffer allocate(int capacity) {
|
|
return ByteBuffer.allocate(capacity);
|
|
}
|
|
|
|
public void dispose(ByteBuffer b) {
|
|
// ignore
|
|
}
|
|
};
|
|
|
|
Factory direct = new Factory() {
|
|
public ByteBuffer allocate(int capacity) {
|
|
return ByteBuffer.allocateDirect(capacity);
|
|
}
|
|
|
|
public void dispose(ByteBuffer b) {
|
|
// ignore
|
|
}
|
|
};
|
|
|
|
Factory native_ = new Factory() {
|
|
public ByteBuffer allocate(int capacity) {
|
|
return allocateNative(capacity);
|
|
}
|
|
|
|
public void dispose(ByteBuffer b) {
|
|
freeNative(b);
|
|
}
|
|
};
|
|
|
|
test(array, array);
|
|
test(array, direct);
|
|
test(array, native_);
|
|
|
|
test(direct, array);
|
|
test(direct, direct);
|
|
test(direct, native_);
|
|
|
|
test(native_, array);
|
|
test(native_, direct);
|
|
test(native_, native_);
|
|
|
|
try {
|
|
ByteBuffer.allocate(1).getInt();
|
|
expect(false);
|
|
} catch (BufferUnderflowException e) {
|
|
// cool
|
|
}
|
|
|
|
try {
|
|
ByteBuffer.allocate(1).getInt(0);
|
|
expect(false);
|
|
} catch (IndexOutOfBoundsException e) {
|
|
// cool
|
|
}
|
|
|
|
try {
|
|
ByteBuffer.allocate(1).putInt(1);
|
|
expect(false);
|
|
} catch (BufferOverflowException e) {
|
|
// cool
|
|
}
|
|
|
|
try {
|
|
ByteBuffer.allocate(1).putInt(0, 1);
|
|
expect(false);
|
|
} catch (IndexOutOfBoundsException e) {
|
|
// cool
|
|
}
|
|
}
|
|
|
|
private interface Factory {
|
|
public ByteBuffer allocate(int capacity);
|
|
|
|
public void dispose(ByteBuffer b);
|
|
}
|
|
}
|