com.xxdb.data.BasicBooleanVector Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dolphindb-javaapi Show documentation
Show all versions of dolphindb-javaapi Show documentation
The messaging and data conversion protocol between Java and DolphinDB server
package com.xxdb.data;
import com.xxdb.io.ExtendedDataInput;
import com.xxdb.io.ExtendedDataOutput;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.util.Arrays;
import java.util.List;
/**
*
* Corresponds to DolphinDB bool vector
*
*/
public class BasicBooleanVector extends AbstractVector{
private byte[] values;
private int size;
private int capaticy;
public BasicBooleanVector(int size){
this(DATA_FORM.DF_VECTOR, size);
}
public BasicBooleanVector(List list){
super(DATA_FORM.DF_VECTOR);
if (list != null) {
values = new byte[list.size()];
for (int i=0; i getElementClass(){
return BasicBoolean.class;
}
@Override
public int rows() {
return size;
}
protected void writeVectorToOutputStream(ExtendedDataOutput out) throws IOException{
byte[] data = new byte[size];
System.arraycopy(values, 0, data, 0, size);
out.write(data);
}
@Override
public int asof(Scalar value) {
throw new RuntimeException("BasicBooleanVector.asof not supported.");
}
@Override
public int getUnitLength(){
return 1;
}
public void add(byte value) {
if (size + 1 > capaticy && values.length > 0){
values = Arrays.copyOf(values, values.length * 2);
}else if (values.length <= 0){
values = Arrays.copyOf(values, values.length + 1);
}
capaticy = values.length;
values[size] = value;
size++;
}
public void addRange(byte[] valueList) {
values = Arrays.copyOf(values, valueList.length + values.length);
System.arraycopy(valueList, 0, values, size, valueList.length);
size += valueList.length;
capaticy = values.length;
}
@Override
public void Append(Scalar value) throws Exception{
add(value.getNumber().byteValue());
}
@Override
public void Append(Vector value) throws Exception{
addRange(((BasicBooleanVector)value).getdataArray());
}
public byte[] getdataArray(){
byte[] data = new byte[size];
System.arraycopy(values, 0, data, 0, size);
return data;
}
@Override
public ByteBuffer writeVectorToBuffer(ByteBuffer buffer) throws IOException {
byte[] data = new byte[size];
System.arraycopy(values, 0, data, 0, size);
for (byte val: data) {
buffer.put(val);
}
return buffer;
}
@Override
public int serialize(int indexStart, int offect, int targetNumElement, NumElementAndPartial numElementAndPartial, ByteBuffer out) throws IOException{
targetNumElement = Math.min((out.remaining() / getUnitLength()), targetNumElement);
for (int i = 0; i < targetNumElement; ++i)
{
out.put(values[indexStart + i]);
}
numElementAndPartial.numElement = targetNumElement;
numElementAndPartial.partial = 0;
return targetNumElement;
}
public byte[] getValues() {
return values;
}
}