其他分享
首页 > 其他分享> > 二进制存值

二进制存值

作者:互联网

假设一个人可以购买金卡、银卡、铜卡,怎么存储他的购买情况呢?购没购买可以用1或0表示,为了节省内存可以用一个字段表示,将金卡设置为高位3,银卡次之2,铜卡为低位1,如果在都购买的情况下即为111。

int num = 1 << (cardType.getNumber() - 1);  //cardType.getNumber()为3,则num为4,二进制100

int fixedNum = oldNum | num;  //得到修正值,oldNum初始为0,则修正得4,代表购买了金卡

 

得到高位的值:

int silver = (value >> (3 - 1)) & 1;  //结果为0或1,得到购买情况

验证得到某个数的二进制:

   Long a = 33L;

   System.out.println(a.toBinaryString(a));  //100001

 

红点逻辑:按功能定义要表示的高位到低位,存入map,key为定义的位数,value为true 或false,当为true时表示有红点,false表示一直没有红点或从有到无的过程。

long readpoint = builder.getReadpoint(); //得到红点

 for (Entry<Integer, Boolean> entry : redPointMap.entrySet()) {

          if(entry.getValue()) { //有红点直接修正值 注意位数较多的时候1为long类型即1L

             readpoint |= 1L << (entry.getKey() - 1);

          } else { //变为没有红点则不能直接修正避免溢出

             long n = 1L << (entry.getKey() - 1);

             readpoint = readpoint | n;

             n = ~n;

             readpoint &= n;

          }

      }

      builder.setReadpoint(readpoint);//设置红点

 

标签:readpoint,二进制,long,int,num,购买,存值,1L
来源: https://www.cnblogs.com/jeolyli/p/11195882.html