【PHP基础】位运算与原码,反码,补码
对于有符号的而言:
   ①二进制的最高位是符号位: 0表示正数,1表示负数
   ②正数的原码,反码,补码都一样
   ③负数的反码=它的原码符号位不变,其它位取反(0->1,1->0)
   ④负数的补码=它的反码+1
   ⑤0的反码,补码都是0
   ⑥php没有无符号数,换言之,php中的数都是有符号的
   ⑦在计算机运算的时候,都是以补码的方式来运算的.
php中有4个位运算,分别是”按位与&、按位或|、按位异或^,按
位取反~”,它们的运算规则是:
   按位与& : 两位全为1,结果为1
   按位或|  :   两位有一个为1,结果为1
   按位异或 ^ : 两位一个为0,一个为1,结果为1
   按位取反 :   0->1 ,1->0
练习题:
一、       ~-5=?
a.   先找-5的原码     10000000  00000000  00000000  00000101
b.   再找-5的反码     11111111  11111111  11111111  11111010           【原码符号位不变,其它位取反(0->1,1->0)】
c.         -5的补码     11111111  11111111  11111111  11111011            【反码+1】
d.  按位取反运算~    00000000  00000000  00000000  00000100             【这并不是一个最终结果因为在计算机运算的时候,都是以补码的方式来运算的。所以这一步依然是个补码】
e.  由d能看出这个数是正数,正数的原码,反码,补码都一样,所以  结果就是00000000  00000000  00000000  00000100,   即  ~-5=4
二、         2&3=?
a.   2的补码     00000000  00000000  00000000  00000010  
b.   3的补码     00000000  00000000  00000000  00000011
c.按位与运算     00000000  00000000  00000000  00000010      所以结果是    2&3=2
三、        2|3=?
前两步同上,结果是   00000000  00000000  00000000  00000011    结果是  2|3=3
四、 2^3=?
前两步同上,结果是 00000000 00000000 00000000 00000001 结果是 2^3=1
五、        ~2=?
a.          2的补码     00000000  00000000  00000000  00000010
b.          取反运算    11111111  11111111  11111111  11111101   【这一步得到的是运算之后那个数的补码,并不是最终结果】
c.负数的补码推反码   11111111  11111111  11111111  11111100    【补码-1等于反码】
d.负数的反码推原码   10000000  00000000  00000000  00000011    所以  ~2= -3
一个小规律,一个数取反就等于它的相反数再减1。
自己推算 13&7=5 5|4=5 -3^3=-2
【PHP基础】位运算与原码,反码,补码的更多相关文章
- C语言原码反码补码与位运算.
		目录: 一.机器数和真值 二.原码,反码和补码的基础概念 三.为什么要使用原码,反码和补码 四.原码,补码,反码再深入 五.数据溢出测试 六.位运算 ... 
- 「C语言」原码反码补码与位运算
		尽管能查到各种文献,亲自归纳出自己的体系还是更能加深对该知识的理解. 本篇文章便是在结合百度百科有关原码.反码.补码和位运算的介绍并深度借鉴了张子秋和Liquor相关文章后整理而出. 目录 ... 
- java原码反码补码以及位运算
		原码, 反码, 补码的基础概念和计算方法. 对于一个数, 计算机要使用一定的编码方式进行存储. 原码, 反码, 补码是机器存储一个具体数字的编码方式. 1. 原码 原码就是符号位加上真值的绝对值, 即 ... 
- JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)
		一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ... 
- Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题
		一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ... 
- java基础知识-原码,反码,补码
		1.正数:原码,反码,补码:都一样. 2.负数:和正数的储存方式不同,负数都是以补码形式存储的. <1>负数的补码 把负数的原码除了符号位取反后再+1. <2>负数的原码 把对 ... 
- Java基础-原码反码补码
		Java基础-原码反码补码 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 注意,我们这里举列的原码和反码只是为了求负数的补码,在计算机中没有原码,反码的存在,只有补码. 一.原码 ... 
- 原码 & 反码 & 补码 & 详解
		本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ... 
- Java 原码 反码 补码
		本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ... 
- 位移&二进制转换&原码&反码&补码
		<< 左移 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零. 格式 需要移位的数字 << 移位的次数 计算过程 1. 按二进制形式把所有的数字向左 ... 
随机推荐
- Python学习入门基础教程(learning Python)--5.1 Python下文件处理基本过程
			Python下的文件读写操作过程和其他高级语言如C语言的操作过程基本一致,都要经历以下几个基本过程. 1. 打开文件 首先是要打开文件,打开文件的主要目的是为了建立程序和文件之间的联系.按程序访问文件 ... 
- arm_cm4.c关于kinetis的修改
			/***********************************************************************/ /* * Initialize the NVIC t ... 
- CMSIS Example - osTimer  osTimerCreate osTimerStart
			osTimerId timer; uint32_t cnt=; void timerHandler( void * arg ) { cnt++; osTimerStart( timer, ); } o ... 
- CSS去除链接虚线(兼容IE6、IE7)
			在css里加入以下代码: a{ hide-focus: expression( this.hideFocus=true ); outline: none;} 
- Android编程之仿微信显示更多文字的View
			微信朋友圈中,如果好友发表的文字过长,会自动收缩起来,底下有提示,当点击“显示更多”时才会展开. 首先定义布局文件(很简单,不解释): <?xml version="1.0" ... 
- 【HTML】Jquery前台传参及接收
			在一些网页应用中,有的时候需要前台之间传递参数,通过JS语法来做一些判断处理. 发送端:(a页面) <a href="b.html?Show=true" id="t ... 
- [Jobdu] 题目1497:面积最大的全1子矩阵
			题目描述: 在一个M * N的矩阵中,所有的元素只有0和1,从这个矩阵中找出一个面积最大的全1子矩阵,所谓最大是指元素1的个数最多. 输入: 输入可能包含多个测试样例.对于每个测试案例,输入的第一行是 ... 
- linux C(hello world) 解方程
- JavaScript中事件捕获(Event capturing)-------------->由外向内,事件冒泡(Event bubblin)---------->由内向外
			addEventListener("click", function() {}, useCapture:false); <!DOCTYPE html> <html ... 
- CSDN蒋涛:我为什么和王峰一起创办极客帮天使基金?
			i 黑马 记者:王静静 7月15日,i黑马在一家咖啡厅见到了CSDN创始人蒋涛,这位中国最大的程序猿社区的创始人,正在经营一份新事业,他和蓝港在线创始人王峰正式成立了天使基金"极客 ... 
