Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8169546
  • 博文数量: 595
  • 博客积分: 13065
  • 博客等级: 上将
  • 技术积分: 10334
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-26 16:44
个人简介

推荐: blog.csdn.net/aquester https://github.com/eyjian https://www.cnblogs.com/aquester http://blog.chinaunix.net/uid/20682147.html

文章分类

全部博文(595)

分类: C/C++

2012-05-15 23:47:19

实现下载: inttypes.txt   

处理网络程序的字节序,是件非常简单的事,但每次使用时,都显示调用ntohl之类的转换,仍是一件麻烦的事。怎样做更简单了?

只需要定义出各种网络字节序的类型即可,而这些类型和主机字节序兼容。标准的网络字节序是大字节序,在当今小字节序横行的时代,建议以小字节序作为网络字节序,只要通讯双方约定好,效果是一样的,但会省去很多转换,节省了CPU。

在定义用于网络通讯的struct时,就可应用网络字节序类型了,一切暗箱操作,对使用者透明,用起来就简单了,下面举个例:

struct Int16 // 实际操作时,可以定义成模板类,这样不用为每一个类型都去写一片了
{
public:
    Int16()
     :_m(0)
    {
    }

    Int16(int16_t m)
    {
        // 将m转换成网络字节序,这里网络字节序可能是小字节序,也可能是大字节序,由编译宏控制
        _m = f(m); 
    }

    Int16& operator =(int16_t m)
    {
        _m = f(m);
    }

    operator int16_t() const
    {
        return  f(_m) ; // 转回成主机字节序
    }

private:
    int16_t _m;
};

消息定义变成:
#pragma pack(4)
struct Message
{
    Int16 a1;
    Int16 a2;
    Int32 b;
    Int32 c;
};
#pragma pack()

Message* msg = new Message;
msg->a1 = x;
msg->a2 = y;
msg->b = z;
msg->c = 0;

// 不用做字节序转换了
socket->send(msg, sizeof(Message));

Message msg;
socket->recv(&msg, sizeof(Message));
int16_t a1 = msg.a1;
阅读(3055) | 评论(2) | 转发(3) |
给主人留下些什么吧!~~

无色T恤2012-05-16 21:18:02

恩恩,说得很清楚了。 不错。顶一个~

Aquester2012-05-16 10:22:59

如果需要细到bit级别,则需要为Int16增加相应的操作方法,用不了位域。