cocos2dx-lua采用pbc解析proto问题修正

本文详细介绍了在Cocos2dx-Lua中使用pbc解析protobuf协议时遇到的嵌套消息解析问题及解决方案。通过自定义decodeAll函数和decodeTable函数,实现了对嵌套消息的正确解析,并解决了decode后的lua table访问不存在字段时的assert问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在cocos2dx-lua中应用pbc解析protobuf协议格式发现,其对嵌套消息的解析很不友好。 经过for pairs循环检验发现,decode方法并没有解析内部嵌套的子消息。

进一步检查发现,子消息的输出格式为table:第一个字段为子消息的名字, 第2个字段为一个奇怪的字符串(一般为子消息的第一个字段)。进行了各种尝试,发现只要访问一次子消息实际存在的字段,则子消息的结构自动输出为正常。

很奇怪吧!大神的代码总是用各种元表奇奇怪怪的实现来追求效率, 而实际游戏开发中总是需要各种通用的写法。

如果不能对字段进行打印调试毫无疑问是没办法正常开发的,最后发现只要针对子消息结构调用一次decode则可以解决嵌套消息无法正常输出的问题。需要编写下面代码

function decodeAll(typename, buffer)
   local ret = decode(typename, buffer, length)
   if ret then
      decodeTable(ret)
   end
   return ret
end

function decodeTable(tbl)
   for k,v in pairs(tbl) do
       if type(v) == "table" then
          --这里的xxxx请自行替换成protobuf的package
          if(type(v[1]) == "string" and string.find(v[1],"XXXXX.")) then
               local ret = decode(v[1], v[2])
               if ret then
                  tbl[k] = ret
               end
          end
          decodeTable(tbl[k])
       end
   end
end

  游戏中调用protobuf.decodeAll即可正常解析了

另外发现decode后的lua table在访问不存在的字段会报assert, 修改下面这个方法可以解决这个问题

function _decode_type_meta:__index(key)
    local t, msg = c._env_type(P, self._CType, key)
    --local func = assert(_reader[t], key)(msg)
    local reader = _reader[t]
    local func
    if reader then
        func = reader(msg)
    else
        func = function() end
    end
    self[key] = func
    return func
end

  这样我们就可以在游戏中比较友好的使用pbc来解析proto格式了

 

转载于:https://www.cnblogs.com/ColaZhang/p/5156105.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值