开发中总是存在着各种状态的保持。都是字段的话,相当麻烦。使用二进制状态存储就方便多了。现在一个int值你可以保存32个开关了。
10111 = 2^4+2^2+2^1+2^0=16+4+2+1=23
第1个开关(10111右边第1位) 23&2^(1-1)=23&1=1 二进制是1 位运算 1>>(1-1)=1 表示开
第2个开关(10111右边第2位) 23&2^(2-1)=23&2=2 二进制是10 位运算 2>>(2-1)=1 表示开
第3个开关(10111右边第3位) 23&2^(3-1)=23&4=4 二进制是100 位运算 4>>(3-1)=1 表示开
第4个开关(10111右边第4位) 23&2^(4-1)=23&8=0 二进制是0 表示关闭
第5个开关(10111右边第5位) 23&2^(5-1)=23&16=16 二进制是10000 位运算 16>>(5-1)=1 表示开
。。。
第n个开关(10111右边第n位) 23&2^(n-1)=a 二进制是? 位运算 a>>(n-1)=1 表示X
package com.yh.tools.binarySwitch;
/**
* @Description: 使用一个int的二进制形式表示最多32个(32位)开关的状态。10111从右向左是开开开关开,一共五位。10进制用23表示
* @CreateDate: 2018/8/2 14:31
* @UpdateRe