【c++】15.订阅消息后转化为proto消息,再序列化,最后通过tcp发送出去
上位機服務(wù)端訂閱Autosar的AP消息,然后將AP消息通過proto消息的set_xxx(value)等函數(shù)賦值給proto消息編譯后的結(jié)構(gòu)體類型,例如:
下面的proto_msg 是由xx.proto編譯后得到的結(jié)構(gòu)體類型,就是我們要賦值的proto結(jié)構(gòu)。
其中add_xx()函數(shù),xx是proto_msg結(jié)構(gòu)中的repeated類型,要向proto結(jié)構(gòu)中增加一個xx,就使用add_xx()。
給proto_msg中的id變量進行賦值就使用set_id(value);
然后使用proto_msg.ByteSize()獲取proto消息的字節(jié)長度,并填充TCP/UDP 數(shù)據(jù)包頭,然后再把proto消息序列化到TCP/UDP 數(shù)據(jù)包對應(yīng)位置,最后使用TCP/UDP協(xié)議發(fā)送出去。
static inline void _fill_pack_head(uint32_t type, uint32_t len,netproxy_pack_t *pack_head) {pack_head->begin[0] = 0xaa;pack_head->begin[1] = 0xaa;pack_head->begin[2] = 0xaa;pack_head->begin[3] = 0xaa;pack_head->type = type;pack_head->len = len; } #define _fill_pack(proto_msg) \{ \char tbuf[256 * 1024]; /** 256KB **/ \uint32_t len = proto_msg.ByteSize(); \auto header = proto_msg.header(); \_fill_pack_head(static_cast<uint32_t>(netproxy_##proto_msg##_pack), len, \reinterpret_cast<netproxy_pack_t *>(tbuf)); \if (!proto_msg.SerializeToArray(&tbuf[sizeof(netproxy_pack_t)], len)) { \SERROR << "serialize error, proto_msg name:" << #proto_msg << " len:" << len; \len = -sizeof(netproxy_pack_t); \} \Send_data(tbuf, len + sizeof(netproxy_pack_t), netproxy_##proto_msg##_pack); \}上面的代碼是計算 proto消息proto_msg的字節(jié)長度,然后把proto消息proto_msg序列化存入&tbuf[sizeof(netproxy_pack_t)]位置,在數(shù)組tbuf的sizeof(netproxy_pack_t)之前的位置都是頭占據(jù)著,proto消息proto_msg序列化后放到數(shù)據(jù)包tbuf對應(yīng)位置之后就可以使用TCP/UDP協(xié)議進行發(fā)送了。
總結(jié)
以上是生活随笔為你收集整理的【c++】15.订阅消息后转化为proto消息,再序列化,最后通过tcp发送出去的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【c++】13.必须用指针取值的情况.m
- 下一篇: 【c++】25.事件驱动的详解