假设一个人可以购买金卡、银卡、铜卡,怎么存储他的购买情况呢?购没购买可以用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);//设置红点