当前位置: 首页>>代码示例>>Java>>正文


Java Allocation.getData方法代码示例

本文整理汇总了Java中org.apache.hadoop.hbase.regionserver.MemStoreLAB.Allocation.getData方法的典型用法代码示例。如果您正苦于以下问题:Java Allocation.getData方法的具体用法?Java Allocation.getData怎么用?Java Allocation.getData使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.apache.hadoop.hbase.regionserver.MemStoreLAB.Allocation的用法示例。


在下文中一共展示了Allocation.getData方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: testLABRandomAllocation

import org.apache.hadoop.hbase.regionserver.MemStoreLAB.Allocation; //导入方法依赖的package包/类
/**
 * Test a bunch of random allocations
 */
@Test
public void testLABRandomAllocation() {
  Random rand = new Random();
  MemStoreLAB mslab = new MemStoreLAB();
  int expectedOff = 0;
  byte[] lastBuffer = null;
  // 100K iterations by 0-1K alloc -> 50MB expected
  // should be reasonable for unit test and also cover wraparound
  // behavior
  for (int i = 0; i < 100000; i++) {
    int size = rand.nextInt(1000);
    Allocation alloc = mslab.allocateBytes(size);
    
    if (alloc.getData() != lastBuffer) {
      expectedOff = 0;
      lastBuffer = alloc.getData();
    }
    assertEquals(expectedOff, alloc.getOffset());
    assertTrue("Allocation " + alloc + " overruns buffer",
        alloc.getOffset() + size <= alloc.getData().length);
    expectedOff += size;
  }
}
 
开发者ID:fengchen8086,项目名称:LCIndex-HBase-0.94.16,代码行数:27,代码来源:TestMemStoreLAB.java

示例2: testReusingChunks

import org.apache.hadoop.hbase.regionserver.MemStoreLAB.Allocation; //导入方法依赖的package包/类
@Test
public void testReusingChunks() {
  Random rand = new Random();
  MemStoreLAB mslab = new MemStoreLAB(conf, chunkPool);
  int expectedOff = 0;
  byte[] lastBuffer = null;
  // Randomly allocate some bytes
  for (int i = 0; i < 100; i++) {
    int size = rand.nextInt(1000);
    Allocation alloc = mslab.allocateBytes(size);

    if (alloc.getData() != lastBuffer) {
      expectedOff = 0;
      lastBuffer = alloc.getData();
    }
    assertEquals(expectedOff, alloc.getOffset());
    assertTrue("Allocation " + alloc + " overruns buffer", alloc.getOffset()
        + size <= alloc.getData().length);
    expectedOff += size;
  }
  // chunks will be put back to pool after close
  mslab.close();
  int chunkCount = chunkPool.getPoolSize();
  assertTrue(chunkCount > 0);
  // reconstruct mslab
  mslab = new MemStoreLAB(conf, chunkPool);
  // chunk should be got from the pool, so we can reuse it.
  mslab.allocateBytes(1000);
  assertEquals(chunkCount - 1, chunkPool.getPoolSize());
}
 
开发者ID:tenggyut,项目名称:HIndex,代码行数:31,代码来源:TestMemStoreChunkPool.java


注:本文中的org.apache.hadoop.hbase.regionserver.MemStoreLAB.Allocation.getData方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。