PHP原码,反码,补码介绍
原码:
就是“原来的二进制码”,其实就是我们可以理解的按十进制转换为二进制之后得到的一个字符码。原码在数字上都是可以理解的。但在实际的计算机的运行过程中,却常常不用原码,所以就有反码,补码的问题。
在此基础上,规则:一个二进制数字的第一个位是符号位,0表示正数,1表示负数。
举例:(都以8位为例):
7: 00000111
-7: 10000111
反码:
正数的反码就是其本身。
负数的反码就是将原码的非符号部分,每一位取反。。
举例:
7: 00000111
-7: 11111000
补码:
正数的补码是其本身
负数的反码,符号位不变,其余每一位取反之后,整体加1
举例:
7: 00000111
-7: 11111000+1 = 11111001
加法运算:
减法运算:
总结:
1:数据在CPU内部都是按补码进行运算
2:原码,反码,补码的转换过程是系统内部的工作,且转换时符号位不变
3:用补码运算时,符号位参与运算(即当作一个普通的二进制位的数字进行运算)
管理一组事物(数据)的开关状态
开关状态:就是某种数据,它只有2个值可用:true,false,1,0,开,关。。。
一组事物是指:多个数据的任意可能的出现状态
我们假设有5个灯光的开关需要管理:
1:确定每个灯泡的状态:开,关;
2:可以指定打开任意一个灯泡
3:可以指定关闭任意一个灯泡
设定前提:这5个灯泡有明确的顺序,我们将设定5个变量(常量其实也行)
假设1-5个灯泡的位置从右往左边数--对应数字的位数
第一个灯泡:$d1 = 1; //00000001
第二个灯泡:$d2 = 2; //00000010
第三个灯泡:$d3 = 4; //00000100
第四个灯泡:$d4 = 8; //00001000
第五个灯泡:$d5 = 16; //00010000
则所有灯泡的总的状态,就可以使用一个变量来描述:
如果$state = 7; //00000111 就表示第一,二,三个灯泡亮
如果$state = 9; //00001001 就表示第一,四个灯泡亮
如果$state = 13; //00001101 就表示第一,二,四个灯泡亮
确定一个灯泡的开关状:
$s1 = $state & $dn //这里n表示1-5之间的任意一个
则结果如果$s1 > 0 ,就表示该灯泡亮,否则就表示该灯泡灭
打开指定的灯泡:
$state = $state | $dn; //这里n表示1-5之间的任意一个
关闭指定灯泡:
$state = $state & ~$dn; //这里n表示1-5之间的任意一个
原文地址:http://ginvip.blog.51cto.com/8092345/1712716