标签:readpoint 二进制 long int num 购买 存值 1L
假设一个人可以购买金卡、银卡、铜卡,怎么存储他的购买情况呢?购没购买可以用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
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。