php 字符串计算反码,PHP原码,反码,补码介绍

PHP原码,反码,补码介绍

原码:

就是“原来的二进制码”,其实就是我们可以理解的按十进制转换为二进制之后得到的一个字符码。原码在数字上都是可以理解的。但在实际的计算机的运行过程中,却常常不用原码,所以就有反码,补码的问题。

在此基础上,规则:一个二进制数字的第一个位是符号位,0表示正数,1表示负数。

举例:(都以8位为例):

7:    00000111

-7:    10000111

反码:

正数的反码就是其本身。

负数的反码就是将原码的非符号部分,每一位取反。。

举例:

7:    00000111

-7:    11111000

补码:

正数的补码是其本身

负数的反码,符号位不变,其余每一位取反之后,整体加1

举例:

7:    00000111

-7:    11111000+1 = 11111001

加法运算:

4a33e8307433a8703b3cceb5c913981d.png

减法运算:

bed1fef56c975f39c0d0b86c0ae54c16.png

总结:

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值