位操作的应用

1. 创建RTTI的父类关系。 (数据独位 0010, 0100等)

    使用|合并操作, 见RTTI类的创建。

2. BitSetOne的应用。

    使用% / int[] 数组创建超过32位的位操作。

    使用memcmp快速判断对象为0。

    使用 |= (1<<N)把某一位置成1。

    使用 &= ~(1<<N)把某一位置成0。

3. 加密操作之位异或。

    字符顺序调换(di,倒到,为正),期间注意字符为偶数的情况。主要思想是两边调换顺序不变,A^0 = A; B^B = 0; A^B^B = A; 

    int di = size-1-i;    // size-1 -1 与 i 是对称的数量级

    buffer[i] = buffer[di] ^ encrypt_key[(i+size)%sizeof(encrypt_key)];   

    buffer[i] = buffer[di] ^ encrypt_key[(size-1 -1+size)%sizeof(encrypt_key)];

    //偶数时,中间的特殊处理。

    buffer[size / 2] = buffer[size / 2] ^ ((char*)encrypt_key)[(size / 2 + size) % sizeof(encrypt_key)];

4. 交易类型中判断兼容性。(数据有0独位0000, 0010, 0100等)

   flag1 ^ flag ==0 // 两个元素相同

   flags2 & ITEM_BITS_BIND != 0 ;// 是绑定物品

   if( (flag1 | flag2) & ITEM_BITS_EXCHANGE )  //当两个物品中有任意一个是ITEM_BITS_EXCHANGE,成立

   if ((flags2 & ITEM_BITS_BIND) != (flags1 & ITEM_BITS_BIND)) // 两个物品中有且只有一个是,成立。

   

    

转载于:https://www.cnblogs.com/yizhuxiaohua/p/6010638.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值