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


C++ SerializeOutput::writeBytes方法代码示例

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


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

示例1: serializeColumnHeaderTo

void Table::serializeColumnHeaderTo(SerializeOutput &serialOutput) {
    /* NOTE:
       VoltDBEngine uses a binary template to create tables of single integers.
       It's called m_templateSingleLongTable and if you are seeing a serialization
       bug in tables of single integers, make sure that's correct.
    */

    // skip header position
    std::size_t start;

    // use a cache
    if (m_columnHeaderData) {
        assert(m_columnHeaderSize != -1);
        serialOutput.writeBytes(m_columnHeaderData, m_columnHeaderSize);
        return;
    }
    assert(m_columnHeaderSize == -1);

    start = serialOutput.position();

    // skip header position
    serialOutput.writeInt(-1);

    //status code
    serialOutput.writeByte(-128);

    // column counts as a short
    serialOutput.writeShort(static_cast<int16_t>(m_columnCount));

    // write an array of column types as bytes
    for (int i = 0; i < m_columnCount; ++i) {
        ValueType type = m_schema->columnType(i);
        serialOutput.writeByte(static_cast<int8_t>(type));
    }

    // write the array of column names as voltdb strings
    // NOTE: strings are ASCII only in metadata (UTF-8 in table storage)
    for (int i = 0; i < m_columnCount; ++i) {
        // column name: write (offset, length) for column definition, and string to string table
        const string& name = columnName(i);
        // column names can't be null, so length must be >= 0
        int32_t length = static_cast<int32_t>(name.size());
        assert(length >= 0);

        // this is standard string serialization for voltdb
        serialOutput.writeInt(length);
        serialOutput.writeBytes(name.data(), length);
    }


    // write the header size which is a non-inclusive int
    size_t position = serialOutput.position();
    m_columnHeaderSize = static_cast<int32_t>(position - start);
    int32_t nonInclusiveHeaderSize = static_cast<int32_t>(m_columnHeaderSize - sizeof(int32_t));
    serialOutput.writeIntAt(start, nonInclusiveHeaderSize);

    // cache the results
    m_columnHeaderData = new char[m_columnHeaderSize];
    memcpy(m_columnHeaderData, static_cast<const char*>(serialOutput.data()) + start, m_columnHeaderSize);
}
开发者ID:simonzhangsm,项目名称:voltdb,代码行数:60,代码来源:table.cpp


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