پروتکل بافرز

پروتکل بافرز، یک روش سریالیزه کردن اطلاعات است که توسط گوگل برای استفاده داخلی توسعه یافته بود که بعداً برای استفاده عموم منتشر شد. از این روش برای برقرار کردن ارتباطات بین برنامه‌ها توسط سیم یا ذخیره کردن اطلاعات استفاده می‌شود. این روش شامل یک زبان توصیف میانی و یک کامپایلر که کدهای مختلف برای زبان‌های برنامه‌نویسی مختلف از این زبان توصیف میانی تولید می‌کند، است.

در ابتدای ارائه توسط گوگل، کامپایلر آن فقط برای زبان‌های C++، جاوا و پایتون، کد تولید می‌کرد ولی توسط اشخاص ثالث، برای بسیاری زبان دیگر مانند گو، جاوا‌اسکریپت، سی‌شارپ، روبی، پی اچ پی و.. توسعه یافت. [۱]

مثال

در زبان توصیف میانی، پیام‌هایی که تبادل خواهند شد تعریف می‌شود. تعریف پیام‌ها شبیه تعریف کلاس‌های فقط حاوی اطلاعات در زبان‌های برنامه‌نویسی است. هر فیلد با یک عدد منحصر به فرد هم شماره‌گذاری می‌شود که در تبادل اطلاعات فقط همین شماره منتقل می‌شود تا از ارسال حجم بالای اطلاعات جلوگیری شود.

message Point {
  required int32 x = 1;
  required int32 y = 2;
  optional string label = 3;
}

message Line {
  required Point start = 1;
  required Point end = 2;
  optional string label = 3;
}

message Polyline {
  repeated Point point = 1;
  optional string label = 2;
}

پیام Point، دو فیلد اجباری x و y تعریف می‌کند. فیلد label اختیاری است. پیام‌های Line و Polyline هم استفاده از تجمیع را در پروتکل بافرز نشان می‌دهند (هر دو از Pointاستفاده می‌کنند). Polyline یک فیلد repeated هم دارد که شبیه آرایه در زبان‌های برنامه‌نویسی است.

این کد توسط proto (کامپایلر پروتکل بافرز) کامپایل شده و به عنوان خروجی، کد C++ می‌دهد که می‌تواند اطلاعات را نوشته و بخواند. یک برنامه C++ که از این کد استفاده می‌کند، شبیه زیر می‌تواند باشد:

#include "polyline.pb.h"  // generated by calling protoc polyline.proto (defined above)

Line* createNewLine(const std::string& name) {
  Line* line = new Line;
  line->mutable_start()->set_x(10);
  line->mutable_start()->set_y(20);
  line->mutable_end()->set_x(30);
  line->mutable_end()->set_y(40);
  line->set_label(name);
  return line;
}

Polyline* createNewPolyline() {
  Polyline* polyline = new Polyline;
  Point* point1 = polyline->add_point();
  point1->set_x(10);
  point1->set_y(10);
  Point* point2 = polyline->add_point();
  point2->set_x(10);
  point2->set_y(10);
  return polyline;
}

منابع

پیوند به بیرون