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


C++ auto_ptr::Empty方法代码示例

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


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

示例1: testIOVec

/**
 * Test getting / setting IOVec work.
 */
void IOQueueTest::testIOVec() {
  uint8_t data1[] = {0, 1, 2, 3, 4, 5, 6, 7, 8};

  m_buffer->Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, m_buffer->Size());
  OLA_ASSERT_FALSE(m_buffer->Empty());

  int iocnt;
  const struct IOVec *vector = m_buffer->AsIOVec(&iocnt);
  OLA_ASSERT_EQ(9u, SumLengthOfIOVec(vector, iocnt));
  OLA_ASSERT_EQ(1, iocnt);
  m_buffer->FreeIOVec(vector);

  // try a smaller block size
  MemoryBlockPool pool(4);
  IOQueue queue(&pool);
  m_buffer.reset(new IOQueue(&pool));
  queue.Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, queue.Size());

  vector = queue.AsIOVec(&iocnt);
  OLA_ASSERT_EQ(3, iocnt);
  OLA_ASSERT_EQ(9u, SumLengthOfIOVec(vector, iocnt));
  queue.FreeIOVec(vector);
}
开发者ID:Jurrie,项目名称:ola,代码行数:28,代码来源:IOQueueTest.cpp

示例2: testPeek

/**
 * Test that Peek behaves
 */
void IOQueueTest::testPeek() {
  uint8_t data1[] = {0, 1, 2, 3, 4, 5, 6, 7, 8};

  m_buffer->Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, m_buffer->Size());
  OLA_ASSERT_FALSE(m_buffer->Empty());

  const unsigned int DATA_SIZE = 20;
  uint8_t *output_data = new uint8_t[DATA_SIZE];

  // peek at the first four bytes
  unsigned int output_size = m_buffer->Peek(output_data, 4);
  ASSERT_DATA_EQUALS(__LINE__, data1, 4, output_data, output_size);
  OLA_ASSERT_EQ(9u, m_buffer->Size());

  // peek at the first 9 bytes
  output_size = m_buffer->Peek(output_data, 9);
  ASSERT_DATA_EQUALS(__LINE__, data1, 9, output_data, output_size);
  OLA_ASSERT_EQ(9u, m_buffer->Size());

  // peek at more bytes that exist in the buffer
  output_size = m_buffer->Peek(output_data, DATA_SIZE);
  OLA_ASSERT_EQ(9u, output_size);
  ASSERT_DATA_EQUALS(__LINE__, data1, sizeof(data1), output_data, output_size);
  OLA_ASSERT_EQ(9u, m_buffer->Size());

  // Now try a buffer with smaller blocks
  MemoryBlockPool pool(4);
  IOQueue queue(&pool);
  queue.Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, queue.Size());

  // peek at he same amount as the first block size
  output_size = queue.Peek(output_data, 4);
  ASSERT_DATA_EQUALS(__LINE__, data1, 4, output_data, output_size);
  OLA_ASSERT_EQ(9u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  // peek at data from more than one block
  output_size = queue.Peek(output_data, 6);
  ASSERT_DATA_EQUALS(__LINE__, data1, 6, output_data, output_size);
  OLA_ASSERT_EQ(9u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  // peek at data on the two block boundry
  output_size = queue.Peek(output_data, 8);
  ASSERT_DATA_EQUALS(__LINE__, data1, 8, output_data, output_size);
  OLA_ASSERT_EQ(9u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  // peek at all the data
  output_size = queue.Peek(output_data, 9);
  ASSERT_DATA_EQUALS(__LINE__, data1, 9, output_data, output_size);
  OLA_ASSERT_EQ(9u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  // peek at more data than what exists
  output_size = queue.Peek(output_data, DATA_SIZE);
  OLA_ASSERT_EQ(9u, output_size);
  ASSERT_DATA_EQUALS(__LINE__, data1, 9, output_data, output_size);
  OLA_ASSERT_EQ(9u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  delete[] output_data;
}
开发者ID:Jurrie,项目名称:ola,代码行数:68,代码来源:IOQueueTest.cpp

示例3: testPop

/**
 * Test that Pop behaves
 */
void IOQueueTest::testPop() {
  uint8_t data1[] = {0, 1, 2, 3, 4, 5, 6, 7, 8};

  m_buffer->Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, m_buffer->Size());
  OLA_ASSERT_FALSE(m_buffer->Empty());

  m_buffer->Pop(9);
  OLA_ASSERT_EQ(0u, m_buffer->Size());
  OLA_ASSERT_TRUE(m_buffer->Empty());

  // try to pop off more data
  m_buffer->Pop(1);
  OLA_ASSERT_EQ(0u, m_buffer->Size());
  OLA_ASSERT_TRUE(m_buffer->Empty());

  // add the data back, then try to pop off more than we have
  m_buffer->Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, m_buffer->Size());
  OLA_ASSERT_FALSE(m_buffer->Empty());

  m_buffer->Pop(10);
  OLA_ASSERT_EQ(0u, m_buffer->Size());
  OLA_ASSERT_TRUE(m_buffer->Empty());

  // one more time
  m_buffer->Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, m_buffer->Size());

  // Now try a buffer with smaller blocks
  MemoryBlockPool pool(4);
  IOQueue queue(&pool);
  queue.Write(data1, sizeof(data1));
  OLA_ASSERT_EQ(9u, queue.Size());

  // pop the same amount as the first block size
  queue.Pop(4);
  OLA_ASSERT_EQ(5u, queue.Size());
  OLA_ASSERT_FALSE(queue.Empty());

  // now pop more than the buffer size
  queue.Pop(6);
  OLA_ASSERT_EQ(0u, queue.Size());
  OLA_ASSERT_TRUE(queue.Empty());

  // test the block boundry
  uint8_t *output_data = new uint8_t[4];
  m_buffer.reset(new IOQueue(&pool));
  queue.Write(data1, 4);
  OLA_ASSERT_EQ(4u, queue.Size());
  unsigned int output_size = queue.Peek(output_data, 4);
  ASSERT_DATA_EQUALS(__LINE__, data1, 4, output_data, output_size);
  queue.Pop(4);
  OLA_ASSERT_TRUE(queue.Empty());

  // now add some more data
  queue.Write(data1 + 4, 4);
  OLA_ASSERT_EQ(4u, queue.Size());
  output_size = queue.Peek(output_data, 4);
  ASSERT_DATA_EQUALS(__LINE__, data1 + 4, 4, output_data, output_size);
  queue.Pop(4);
  OLA_ASSERT_TRUE(queue.Empty());

  delete[] output_data;
}
开发者ID:Jurrie,项目名称:ola,代码行数:68,代码来源:IOQueueTest.cpp


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