pragma pack对template结构的作用在VC7与gcc中差别

    最近本人利用template的偏特化编制了一个通用协议数据单元类CPdu。
CPdu的通用包头定义如下:

#pragma pack(push,__PDU__,1)

template<long min_unknown,long max_unknown>
struct CommPduHeader
{
 long len   ; //pdu length,include 'len' filed
 short type  ; //pdu type
 
 ...
};

#pragma pack(pop,__PDU__)

 根据设计,CommPduHeader的实例的尺寸应该是6,例如:
sizeof(CommPduHeader<1,100>)应该为6。在VC7下进行测试,
sizeof(CommPduHeader<1,100>)等于我们的预期值6。在将CPdu移植到
linux是发现sizeof(CommPduHeader<1,100>)则返回的是8,而不是我们预期
的6。这意味着同样采用CPdu定义的通信协议,运行在linux与win32平台上的
通信双方无法正常通信。这直接导致CPdu的设计失效。
    显然,sizeof(CommPduHeader<1,100>)=6才是正确的结果,如果修改
CommPduHeader的定义是的sizeof(CommPduHeader<1,100>)在gcc下也返回6呢?
经过一段时间琢磨和测试,发现以下面的方式重定义CommPduHeader,gcc下
sizeof(CommPduHeader<1,100>)也返回我们的预期值6。

#pragma pack(push,__PDU__,1)

struct CommPduHeaderBase
{
 long len   ; //pdu length,include 'len' filed
 short type  ; //pdu type
};


template<long min_unknown,long max_unknown>
struct CommPduHeader : public CommPduHeaderBase
{
 ...
};

#pragma pack(pop,__PDU__)

修改好的定义,CommPduHeader的用法完全保持不变,而
sizeof(CommPduHeader<1,100>)=6。新的定义在VC7中也返回预期值。
这样,通过调整引入CommPduHeaderBase,CPdu就可以适用于linux和
win32上了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值