C语言中的位操作(12)--判断一个数字是否包含一个全零字节

本文主要介绍一系列算法,算法主要功能是判断一个数字(二进制)中是否包含全零字节

e.g.1010 1111 0000 0000 1001 1111 0001 1111

即 32位整数:A4A3A2A1中Ai =0(i=1 or 2 or 3 or 4)

// 较少操作算法版本:
unsigned int v; // 32位整型目标整数判断是否包含全0字节
bool hasZeroByte = ~((((v & 0x7F7F7F7F) + 0x7F7F7F7F) | v) | 0x7F7F7F7F);

原理:

0x7F7F7F7F=0111 1111 0111 1111 0111 1111 0111 1111

v & 0x7F7F7F7F:将v的第8、16、24、32位都置为0,其余位不变

我们不妨设A2=0

执行完 (v & 0x7F7F7F7F)+0x7F7F7F7F , A2=0111 1111

再执行(v & 0x7F7F7F7F)+0x7F7F7F7F | v, A2=0111 1111

执行 ((v & 0x7F7F7F7F)+0x7F7F7F7F | v) | 0x7F7F7F7F, A2=0111 1111

最后执行 ~(((v & 0x7F7F7F7F)+0x7F7F7F7F | v) | 0x7F7F7F7F) A2=1000 0000 !=0

hasZeroByte=true

 

操作步骤较多的算法:

bool hasNoZeroByte = ((v & 0xff) && (v & 0xff00) && (v & 0xff0000) && (v & 0xff000000))

或者如下的算法:

unsigned char * p = (unsigned char *) &v;  
bool hasNoZeroByte = *p && *(p + 1) && *(p + 2) && *(p + 3);

原理比较简单

 

转载于:https://www.cnblogs.com/xueda120/p/3147406.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值