时间:2021-07-01 10:21:17 帮助过:16人阅读
define("T_CHINESE", 1); //中文 define("T_SEP", 1 << 1); //分割符合 define("T_NUM", 1 << 2); //数字 define("T_INDEX", 1 << 3); //索引 define("T_LETTER", 1 << 4); //字母 define("T_WORD", 1 << 5); //正常单词 define("T_OTHER", 1 << 6);
用一个Int 的位,表示一种类型。比如中文数字就是 T_CHINESE | T_NUM,为什么可以这样用?
看到的书上都是简单介绍下二进制运算,并没有相关运用,哪儿可以补相关知识。
经常看到这种二进制运算
define("T_CHINESE", 1); //中文 define("T_SEP", 1 << 1); //分割符合 define("T_NUM", 1 << 2); //数字 define("T_INDEX", 1 << 3); //索引 define("T_LETTER", 1 << 4); //字母 define("T_WORD", 1 << 5); //正常单词 define("T_OTHER", 1 << 6);
用一个Int 的位,表示一种类型。比如中文数字就是 T_CHINESE | T_NUM,为什么可以这样用?
看到的书上都是简单介绍下二进制运算,并没有相关运用,哪儿可以补相关知识。
实际上你对这个问题看得这么费力,是因为php本身造成的,为什么这么说呢?因为在php 5.4之前,它居然不支持直接的二进制表达数字,比如我们在其它语言里常见的0b0001
,在php里是无法识别的,而只支持16进制的0x01
。在php 5.4里终于加入了对0b
表达二进制数的支持,因此上面的代码可以用如下方法表达
define("T_CHINESE", 0b0000001); //中文 define("T_SEP", 0b0000010); //分割符合 define("T_NUM", 0b0000100); //数字 define("T_INDEX", 0b0001000); //索引 define("T_LETTER", 0b0010000); //字母 define("T_WORD", 0b0100000); //正常单词 define("T_OTHER", 0b1000000);
移位运算也非常简单,通过我对上面的代码的转换可以很容易看出来
1 << 1 = 0b0000001 << 1 = 0b0000010 // 可以直观的看到,所有数字左移一位
而逻辑运算就更简单了
这种掩码位操作在相对底层一点的高级语言(比如C)里用得比较多, 你可以用一个32bit的无符号int(4字节)保存32个状态, 相对来讲比较省内存
比如STATUS = 0xffffffff & ( T_CHINESE | T_INDEX ); //代表既是中文又是索引
那判断状态的时候 STATUS & T_CHINESE 或者 STATUS & T_INDEX 返回的就是正值,代表中文,索引
而 STATUS & T_NUM 或者STATUS & T_LETTER返回的就是0, 代表非数字非字母了