當前位置: 首頁>>代碼示例>>Java>>正文


Java AllocationHelper.allocateNew方法代碼示例

本文整理匯總了Java中org.apache.drill.exec.vector.AllocationHelper.allocateNew方法的典型用法代碼示例。如果您正苦於以下問題:Java AllocationHelper.allocateNew方法的具體用法?Java AllocationHelper.allocateNew怎麽用?Java AllocationHelper.allocateNew使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.drill.exec.vector.AllocationHelper的用法示例。


在下文中一共展示了AllocationHelper.allocateNew方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: doAlloc

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
private boolean doAlloc() {
  //Allocate vv in the allocationVectors.
  for (final ValueVector v : this.allocationVectors) {
    AllocationHelper.allocateNew(v, incoming.getRecordCount());
  }

  //Allocate vv for complexWriters.
  if (complexWriters == null) {
    return true;
  }

  for (final ComplexWriter writer : complexWriters) {
    writer.allocate();
  }

  return true;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:18,代碼來源:ProjectRecordBatch.java

示例2: doAlloc

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
private boolean doAlloc(int recordCount) {
  //Allocate vv in the allocationVectors.
  for (final ValueVector v : this.allocationVectors) {
    AllocationHelper.allocateNew(v, recordCount);
  }

  //Allocate vv for complexWriters.
  if (complexWriters == null) {
    return true;
  }

  for (final ComplexWriter writer : complexWriters) {
    writer.allocate();
  }

  return true;
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:18,代碼來源:ProjectRecordBatch.java

示例3: doAlloc

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
private boolean doAlloc() {
  for (ValueVector v : allocationVectors) {
    try {
      AllocationHelper.allocateNew(v, current.getRecordCount());
    } catch (OutOfMemoryRuntimeException ex) {
      return false;
    }
  }
  return true;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:11,代碼來源:UnionAllRecordBatch.java

示例4: constructSpecialBatch

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
/**
 * Method is invoked when we have a straight aggregate (no group by expression) and our input is empty.
 * In this case we construct an outgoing batch with record count as 1. For the nullable vectors we don't set anything
 * as we want the output to be NULL. For the required vectors (only for count()) we set the value to be zero since
 * we don't zero out our buffers initially while allocating them.
 */
private void constructSpecialBatch() {
  int exprIndex = 0;
  for (final VectorWrapper<?> vw: container) {
    final ValueVector vv = vw.getValueVector();
    AllocationHelper.allocateNew(vv, SPECIAL_BATCH_COUNT);
    vv.getMutator().setValueCount(SPECIAL_BATCH_COUNT);
    if (vv.getField().getType().getMode() == TypeProtos.DataMode.REQUIRED) {
      if (vv instanceof FixedWidthVector) {
        /*
         * The only case we should have a required vector in the aggregate is for count function whose output is
         * always a FixedWidthVector (BigIntVector). Zero out the vector.
         */
        ((FixedWidthVector) vv).zeroVector();
      } else {
        /*
         * If we are in this else block it means that we have a required vector which is of variable length. We
         * should not be here, raising an error since we have set the record count to be 1 and not cleared the
         * buffer
         */
        throw new DrillRuntimeException("FixedWidth vectors is the expected output vector type. " +
            "Corresponding expression: " + popConfig.getExprs()[exprIndex].toString());
      }
    }
    exprIndex++;
  }
  container.setRecordCount(SPECIAL_BATCH_COUNT);
  recordCount = SPECIAL_BATCH_COUNT;
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:35,代碼來源:StreamingAggBatch.java

示例5: populatePartitionVectors

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
protected void populatePartitionVectors(int recordCount) {
  for (int i = 0; i < pVectors.size(); i++) {
    final ValueVector vector = pVectors.get(i);
    final Object val = selectedPartitionValues.get(i);

    AllocationHelper.allocateNew(vector, recordCount);

    if (val != null) {
      HiveUtilities.populateVector(vector, managedBuffer, val, 0, recordCount);
    }

    vector.getMutator().setValueCount(recordCount);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:15,代碼來源:HiveRecordReader.java

示例6: constructSpecialBatch

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
/**
 * Method is invoked when we have a straight aggregate (no group by expression) and our input is empty.
 * In this case we construct an outgoing batch with record count as 1. For the nullable vectors we don't set anything
 * as we want the output to be NULL. For the required vectors (only for count()) we set the value to be zero since
 * we don't zero out our buffers initially while allocating them.
 */
@SuppressWarnings("resource")
private void constructSpecialBatch() {
  int exprIndex = 0;
  for (final VectorWrapper<?> vw: container) {
    final ValueVector vv = vw.getValueVector();
    AllocationHelper.allocateNew(vv, SPECIAL_BATCH_COUNT);
    vv.getMutator().setValueCount(SPECIAL_BATCH_COUNT);
    if (vv.getField().getType().getMode() == TypeProtos.DataMode.REQUIRED) {
      if (vv instanceof FixedWidthVector) {
        /*
         * The only case we should have a required vector in the aggregate is for count function whose output is
         * always a FixedWidthVector (BigIntVector). Zero out the vector.
         */
        ((FixedWidthVector) vv).zeroVector();
      } else {
        /*
         * If we are in this else block it means that we have a required vector which is of variable length. We
         * should not be here, raising an error since we have set the record count to be 1 and not cleared the
         * buffer
         */
        throw new DrillRuntimeException("FixedWidth vectors is the expected output vector type. " +
            "Corresponding expression: " + popConfig.getExprs().get(exprIndex).toString());
      }
    }
    exprIndex++;
  }
  container.setRecordCount(SPECIAL_BATCH_COUNT);
  recordCount = SPECIAL_BATCH_COUNT;
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:36,代碼來源:StreamingAggBatch.java

示例7: next

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
/**
 * To take into account Hive "skip.header.lines.count" property first N values from file are skipped.
 * Since file can be read in batches (depends on TARGET_RECORD_COUNT), additional checks are made
 * to determine if it's new file or continuance.
 *
 * To take into account Hive "skip.footer.lines.count" property values are buffered in queue
 * until queue size exceeds number of footer lines to skip, then first value in queue is retrieved.
 * Buffer of value objects is used to re-use value objects in order to reduce number of created value objects.
 * For each new file queue is cleared to drop footer lines from previous file.
 */
@Override
public int next() {
  for (ValueVector vv : vectors) {
    AllocationHelper.allocateNew(vv, TARGET_RECORD_COUNT);
  }
  if (empty) {
    setValueCountAndPopulatePartitionVectors(0);
    return 0;
  }

  try {
    skipRecordsInspector.reset();
    int recordCount = 0;
    Object value;
    while (recordCount < TARGET_RECORD_COUNT && reader.next(key, value = skipRecordsInspector.getNextValue())) {
      if (skipRecordsInspector.doSkipHeader(recordCount++)) {
        continue;
      }
      Object bufferedValue = skipRecordsInspector.bufferAdd(value);
      if (bufferedValue != null) {
        Object deSerializedValue = partitionSerDe.deserialize((Writable) bufferedValue);
        if (partTblObjectInspectorConverter != null) {
          deSerializedValue = partTblObjectInspectorConverter.convert(deSerializedValue);
        }
        readHiveRecordAndInsertIntoRecordBatch(deSerializedValue, skipRecordsInspector.getActualCount());
        skipRecordsInspector.incrementActualCount();
      }
      skipRecordsInspector.incrementTempCount();
    }

    setValueCountAndPopulatePartitionVectors(skipRecordsInspector.getActualCount());
    skipRecordsInspector.updateContinuance();
    return skipRecordsInspector.getActualCount();
  } catch (IOException | SerDeException e) {
    throw new DrillRuntimeException(e);
  }
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:48,代碼來源:HiveRecordReader.java

示例8: next

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
@Override
public int next() {
  for (ValueVector vv : vectors) {
    AllocationHelper.allocateNew(vv, TARGET_RECORD_COUNT);
  }

  if (empty) {
    setValueCountAndPopulatePartitionVectors(0);
    return 0;
  }

  try {
    // starting new batch, reset processed records count
    recordsInspector.reset();

    // process records till batch is full or all records were processed
    while (!recordsInspector.isBatchFull() && hasNextValue(recordsInspector.getValueHolder())) {
      Object value = recordsInspector.getNextValue();
      if (value != null) {
        Object deSerializedValue = partitionSerDe.deserialize((Writable) value);
        if (partTblObjectInspectorConverter != null) {
          deSerializedValue = partTblObjectInspectorConverter.convert(deSerializedValue);
        }
        readHiveRecordAndInsertIntoRecordBatch(deSerializedValue, recordsInspector.getProcessedRecordCount());
        recordsInspector.incrementProcessedRecordCount();
      }
    }
    setValueCountAndPopulatePartitionVectors(recordsInspector.getProcessedRecordCount());
    return recordsInspector.getProcessedRecordCount();
  } catch (SerDeException e) {
    throw new DrillRuntimeException(e);
  }
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:34,代碼來源:HiveRecordReaders.java

示例9: allocateVectors

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
/**
 * Simple method to allocate space for all the vectors in the container.
 */
private void allocateVectors() {
  for (final VectorWrapper<?> vw : container) {
    AllocationHelper.allocateNew(vw.getValueVector(), MAX_BATCH_SIZE);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:9,代碼來源:NestedLoopJoinBatch.java

示例10: allocateVectors

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
private void allocateVectors(int targetRecordCount) {
  for (VectorWrapper w: outgoing) {
    AllocationHelper.allocateNew(w.getValueVector(), targetRecordCount);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:6,代碼來源:PriorityQueueCopierTemplate.java

示例11: allocateVectors

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
public static void allocateVectors(VectorAccessible va, int targetRecordCount) {
  for (VectorWrapper<?> w: va) {
    AllocationHelper.allocateNew(w.getValueVector(), targetRecordCount);
  }
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:6,代碼來源:VectorAccessibleUtilities.java

示例12: allocateVectors

import org.apache.drill.exec.vector.AllocationHelper; //導入方法依賴的package包/類
public static void allocateVectors(Iterable<ValueVector> valueVectors, int count) {
  for (final ValueVector v : valueVectors) {
    AllocationHelper.allocateNew(v, count);
  }
}
 
開發者ID:axbaretto,項目名稱:drill,代碼行數:6,代碼來源:VectorUtil.java


注:本文中的org.apache.drill.exec.vector.AllocationHelper.allocateNew方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。