经常看到这种二进制运算
define(t_chinese, 1); //中文 define(t_sep, 1 用一个int 的位,表示一种类型。比如中文数字就是 t_chinese | t_num,为什么可以这样用?
看到的书上都是简单介绍下二进制运算,并没有相关运用,哪儿可以补相关知识。
回复内容: 经常看到这种二进制运算
define(t_chinese, 1); //中文 define(t_sep, 1 用一个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 而逻辑运算就更简单了
这种掩码位操作在相对底层一点的高级语言(比如c)里用得比较多, 你可以用一个32bit的无符号int(4字节)保存32个状态, 相对来讲比较省内存
比如status = 0xffffffff & ( t_chinese | t_index ); //代表既是中文又是索引
那判断状态的时候 status & t_chinese 或者 status & t_index 返回的就是正值,代表中文,索引
而 status & t_num 或者status & t_letter返回的就是0, 代表非数字非字母了