Home >Backend Development >C++ >How Can I Implement Delimited I/O for Protocol Buffers in C ?

How Can I Implement Delimited I/O for Protocol Buffers in C ?

DDD
DDDOriginal
2024-12-06 06:11:12663browse

How Can I Implement Delimited I/O for Protocol Buffers in C  ?

Implementing Delimited I/O Functions in C for Protocol Buffers

In Java, Protocol Buffers version 2.1.0 introduced delimited I/O functions to facilitate reading and writing multiple messages from files. These functions, parseDelimitedFrom, mergeDelimitedFrom, and writeDelimitedTo, work by attaching length prefixes to the messages.

The original question inquired about the existence of equivalent functions for C . While the Java API provides these functions, the official C library initially lacked them. However, as of version 3.3.0, Google added these functions to google/protobuf/util/delimited_message_util.h.

If you are using an older version of the C library, you can implement delimited I/O using the following code:

bool writeDelimitedTo(
    const google::protobuf::MessageLite& message,
    google::protobuf::io::ZeroCopyOutputStream* rawOutput) {
  // Create a new coded stream for each message.
  google::protobuf::io::CodedOutputStream output(rawOutput);

  // Write the message size.
  const int size = message.ByteSize();
  output.WriteVarint32(size);

  uint8_t* buffer = output.GetDirectBufferForNBytesAndAdvance(size);
  if (buffer != NULL) {
    // Optimization: Serialize message directly to array if it fits.
    message.SerializeWithCachedSizesToArray(buffer);
  } else {
    // Slower path for messages spanning multiple buffers.
    message.SerializeWithCachedSizes(&output);
    if (output.HadError()) return false;
  }

  return true;
}

bool readDelimitedFrom(
    google::protobuf::io::ZeroCopyInputStream* rawInput,
    google::protobuf::MessageLite* message) {
  // Create a new coded stream for each message.
  google::protobuf::io::CodedInputStream input(rawInput);

  // Read the message size.
  uint32_t size;
  if (!input.ReadVarint32(&size)) return false;

  // Limit the stream to the message size.
  google::protobuf::io::CodedInputStream::Limit limit =
      input.PushLimit(size);

  // Parse the message.
  if (!message->MergeFromCodedStream(&input)) return false;
  if (!input.ConsumedEntireMessage()) return false;

  // Release the stream limit.
  input.PopLimit(limit);

  return true;
}

The above is the detailed content of How Can I Implement Delimited I/O for Protocol Buffers in C ?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn