002&和&&的区别
来源:互联网 发布:绝知的意思 编辑:程序博客网 时间:2024/04/29 13:41
&和&&都可以用作逻辑与的运算符,表示逻辑与(and),当运算符两边的表达式的结果都为true时,整个运算结果才为true,否则,只要有一方为false,则结果为false。&&还具有短路的功能,即如果第一个表达式为false,则不再计算第二个表达式,例如,对于if(str != null && !str.equals(“”))表达式,当str为null时,后面的表达式不会执行,所以不会出现NullPointerException如果将&&改为&,则会抛出NullPointerException异常。If(x==33 & ++y>0) y会增长,If(x==33 && ++y>0)不会增长&还可以用作位运算符,当&操作符两边的表达式不是boolean类型时,&表示按位与操作,我们通常使用0x0f来与一个整数进行&运算,来获取该整数的最低4个bit位,例如,0x31 & 0x0f的结果为0x01。补充位运算 Java 位运算 移位运算符 包括: “>> 右移”;“<< 左移”;“>>> 无符号右移”例子:-5>>3=-11111 1111 1111 1111 1111 1111 1111 10111111 1111 1111 1111 1111 1111 1111 1111其结果与 Math.floor((double)-5/(2*2*2)) 完全相同。-5<<3 -40="" 1111="" 1111="" 1111="" 1111="" 1111="" 1111="" 1111="" 1011="" 1111="" 1111="" 1111="" 1111="" 1111="" 1111="" 1101="" 1000="" -5="" 2="" 2="" 2="" 5="">>3=00000 0000 0000 0000 0000 0000 0000 01010000 0000 0000 0000 0000 0000 0000 0000其结果与 5/(2*2*2) 完全相同。5<<3 40="" 0000="" 0000="" 0000="" 0000="" 0000="" 0000="" 0000="" 0101="" 0000="" 0000="" 0000="" 0000="" 0000="" 0000="" 0010="" 1000="" 5="" 2="" 2="" 2="" -5="">>>3=536870911 1111 1111 1111 1111 1111 1111 1111 10110001 1111 1111 1111 1111 1111 1111 1111无论正数、负数,它们的右移、左移、无符号右移 32 位都是其本身,比如 -5<<32 -5="" -5="">>32=-5、-5>>>32=-5。一个有趣的现象是,把 1 左移 31 位再右移 31 位,其结果为 -1。0000 0000 0000 0000 0000 0000 0000 00011000 0000 0000 0000 0000 0000 0000 00001111 1111 1111 1111 1111 1111 1111 1111位逻辑运算符 包括: & 与;| 或;~ 非(也叫做求反);^ 异或 “& 与”、“| 或”、“~ 非”是基本逻辑运算,由此可以演变出“与非”、“或非”、“与或非”复合逻辑运算。“^ 异或”是一种特殊的逻辑运算,对它求反可以得到“同或”,所以“同或”逻辑也叫“异或非”逻辑。例子:5&3=10000 0000 0000 0000 0000 0000 0000 01010000 0000 0000 0000 0000 0000 0000 00110000 0000 0000 0000 0000 0000 0000 0001-5&3=11111 1111 1111 1111 1111 1111 1111 10110000 0000 0000 0000 0000 0000 0000 00110000 0000 0000 0000 0000 0000 0000 00115|3=70000 0000 0000 0000 0000 0000 0000 01010000 0000 0000 0000 0000 0000 0000 00110000 0000 0000 0000 0000 0000 0000 0111-5|3=-51111 1111 1111 1111 1111 1111 1111 10110000 0000 0000 0000 0000 0000 0000 00111111 1111 1111 1111 1111 1111 1111 1011~5=-60000 0000 0000 0000 0000 0000 0000 01011111 1111 1111 1111 1111 1111 1111 1010~-5=41111 1111 1111 1111 1111 1111 1111 10110000 0000 0000 0000 0000 0000 0000 01005^3=60000 0000 0000 0000 0000 0000 0000 01010000 0000 0000 0000 0000 0000 0000 00110000 0000 0000 0000 0000 0000 0000 0110-5^3=-81111 1111 1111 1111 1111 1111 1111 10110000 0000 0000 0000 0000 0000 0000 00111111 1111 1111 1111 1111 1111 1111 100032>3>3>
- 002&和&&的区别
- 和和的区别
- & 和 &&、|和||的区别:
- &和&&、|和||的区别
- &&和&,||和|的区别
- &和&&、|和||的区别
- &和&&、|和||的区别
- ../和./和/的区别
- &和&&,|和||的区别
- "&"和"&&"、"|"和"||"的区别
- &和&& |和||的区别
- &和&&的区别 |和||的区别
- &&和&的区别,||和|的区别
- &和&&的区别以及|和||的区别
- &&和&的区别? | | 和|的区别?
- &和&&的区别,|和||的区别
- 002 Asp.Net和ASP的区别
- &和&&的区别及!和~区别
- JAVA之数组
- [珠玑之椟]二分思想与分治法、排序思想
- 藏獒信息网沈乐:耐住寂寞去学习 耐住时间去成长
- 黑马程序员 Java 交通灯管理系统
- (简单LCA) Nearest Common Ancestors(P1330)
- 002&和&&的区别
- 黑马程序员---IO流
- Unity3d 编译发布到安卓平台时出现的问题集
- hdu3746之KMP应用
- 2013-7-9 linux
- Hadoop 2.0 NameNode HA和Federation实践
- ASP.NET中的序列化
- linux vi
- Hadoop Namenode HA方案比较