字节对齐和移位操作

1.字节对齐

int main()
{
#pragma pack(1)
    struct test {
        char a;
        short b;
        int c;
        long d;
    };
   const testLen=sizeof(test);
    return 0;
}

如果程序前面加上#pragma pack(1)则程序为1字节对齐,得到(1+2+4+8)=15,如果不加的话,则需要保证结构体每个元素都要数据对齐,因此必须在a和b之间插入1字节的间隙使得后面的short元素2字节对齐int元素4字节对齐long元素8字节对齐,这样最终test结构大小为16字节。

2.移位操作

#include<iostream>
struct testStr
{
	unsigned short IPAddressParam;  //2
	unsigned char  MUZHIDataLen;   //  1
	unsigned char  MUZHINum;      //  1
	unsigned short targetFW;     //2
	unsigned short targetFY;     //2
	unsigned short targetDistance;   //2
};

struct testStrReplace
{
	unsigned short IPAddressParam;  //2
	unsigned char  MUZHIDataLen;   //  1
	unsigned char  MUZHINum;      //  1
	unsigned short  targetFWD         :8,   
                    targetFWG         :8;//2
	unsigned short targetFY;     //2
	unsigned short targetDistance;   //2
};

int main()
{
	testStr test;
	testStrReplace testR;
	const unsigned short fw = 9200;
	//要求低位在前,高位在后
	//转化为16位   fw&0xff 表示低8位,然后左移8位,得到低8位;
	//fw右移8位,然后&0xff,得到高8位
	test.targetFW = ((fw & 0xff) << 8) | ((fw >> 8) & 0xff);

	//这种写法比较简单,不用移位操作
	testR.targetFWD = fw & 0xff;
	testR.targetFWG = (fw >> 8) & 0xff;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dx0014

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值