`
chen930724
  • 浏览: 373 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

java 位运算

    博客分类:
  • java
阅读更多
位运算是针对底层操作的,在C语言中比较常见,但是在java 中见得就比较少了,
但是能用到位运算的地方坚决用位运算。
 
输出一个整数的 2进制:
System.out.println(Integer. toBinaryString(a));
在java 中 
int 类型的整数是  32位的
short 类型的整数是  16位的
long 类型的整数是  64位的
short 类型的整数是 8位的
 
关于 负数:
int a = -1;
System.out.println("-1  =  "Integer.toBinaryString(a));
输出:
-1     =  1111 1111 1111 1111 1111 1111 1111 1111
 
 
 0     =  0000 0000 0000 0000 0000 0000 0000 0000
     
            1000 0000 0000 0000 0000 0000 0000 0000     最小的负整数数  -2147483648
            0111 1111 1111 1111 1111 1111 1111 1111     最大的正整数数   2147483647
 
-18   =  1111 1111 1111 1111 1111 1111 1110 1110
 
 
最高为1 则为负数,java 中没有什么符号型 和无符号型的 整数什么的。
 可以说都是有符号型的。
int 型 2的32位 数  一般为正整数 一般为负整数
 
正整数是在
                  0000 0000 0000 0000 0000 0000 0000 0000   0的基础上加某数
 
负数是在
                 1111 1111 1111 1111 1111 1111 1111 1111   -1的基础上减某数
 
                 1111 1111 1111 1111 1111 1111 1111 1110   -1-1 = -2
 
位运算的操作符有 :
&          |          ~          ^          >>          <<                    >>>
且        或         非       异或       右移        左移               无符号右移
 
同时  &= |=  ^=  >>=  <<=  >>>= 都是合法的。          ~= 不合法   ~ 是一元操作符 所有不行
 
 
&  且运算:
     要两位都为1 &运算的结果在位于
     1&
     1          = 1
     
     0&     
     1          =0
 
       010010  &  
       100111  
    = 000010
 
 
| 或运算:
     两位只要一位为1 结果就为1
     1|1        = 1
     1|0        = 1
     0|0        = 0
     
     
       010010  |
       100111  
    = 110111
 
^ 亦或运算:
     两位 一个1 一个0 就过就为1
     0^0          = 0
     1^1          = 0
     0^1          = 1
 
       010010  ^
       100111  
    =  110101
 
~ 非运算:
     1 变0 ,0 变1
     ~1 = 0
     ~0 = 1
     int a = 18;
     int b = ~a;
    System.out.println("a:"+Integer. toBinaryString(a));
  System. out.println("b:"+Integer. toBinaryString(b));
输出:
    a:                           10010   
    b:11111111111111111111111111101101    
    
    int 类型的数据有32位,所以前面的0 经过非运算都变成了 1
 
 
<< 左移  
普通正整数的左移
int a = 18;
int b = a<<2;
System.out.println(a+ " =   " +Integer.toBinaryString(a));
System.out.println(b+ " =   " +Integer.toBinaryString(b));     
输出:
18 =   10010
72 =   1001000
 
着实是向左移动了2位,    同时  18*2*2 = 74
 向左移多少为代表  该数 乘以 2的多少次方
so:
 int  b = a*8;
可以写成:
 int b = a <<3
来看看 最大正整数的左移:
     0111 1111 1111 1111 1111 1111 1111 1111     最大的正整数数   2147483647
左移两位后
     1111 1111 1111 1111 1111 1111 1111 1100     -4
 
负数的左移:
int a = -4;
int b = a<<2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
-4 =  11111111111111111111111111111100
-16 = 11111111111111111111111111110000
和正数一样 没有什么区别 直接向左移 低位补0  -4 *2*2 = -16  也是乘以2 的2 次方
 
最小的整数:
     1000 0000 0000 0000 0000 0000 0000 0000     最小的负整数数  -2147483648
 
int a = -2147483648;
int b = a<<2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
-2147483648 =     10000000000000000000000000000000
0 =   0
 
向左移2位 则每个位都变成0
 
左移就是 二进制 直接 左移 然后再低位补0  与正负 与否无关
 
>> 右移
正整数的右移:
int a = 18;
int b = a>>2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
18 =  10010
4 =     100
向右移两位 18 后面那两位 10 直接给整没了。
最大正整数 右移:
int a = 2147483647;
int b = a>>2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
2147483647 =      1111111111111111111111111111111
536870911 =         11111111111111111111111111111
直接右移 两位
 
负数的右移:
int a = -4;
int b = a>>2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
-4 =  11111111111111111111111111111100
-1 =  11111111111111111111111111111111
向右移 把-4 后面的两个0 给挤掉了,同时在 高位补1
最小负数的右移:
int a = -2147483648;
int b = a>>2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
-2147483648 =     10000000000000000000000000000000
-536870912 =      11100000000000000000000000000000
也是直接向右移  高位 补1
 
右移: 先直向右移动  然后正数在高位 补0
                                          负数在高位  补1
 
 
>>>  无符号的右移
     就是不管是整数还是负数
     右移 然后再高位补0:
例:
int a = -1;
int b = a>>>2;
System.out.println(a+ " =\t" +Integer.toBinaryString(a));
System.out.println(b+ " =\t" +Integer.toBinaryString(b));
输出:
-1 =                      11111111111111111111111111111111
1073741823 =      111111111111111111111111111111
直接右移 然后找高位补 0
 
 
 
 
 
 
 
     
 
 
 
 
                                   
分享到:
评论

相关推荐

    JAVA位运算.pdf

    ### JAVA位运算详解 在Java编程中,位运算是一门精细的艺术,涉及到对整数类型的二进制位进行直接操作。这些操作不仅能够优化代码执行效率,还常用于实现特定的算法需求。本文将深入探讨Java中的位运算,包括位...

    java位运算操作

    Java位运算操作 左位移 右位移 与或非的操作

    java位运算例子,绝对有用

    java位运算例子,一看就懂,包含符号介绍,每个符号都有相应的例子。

    java位运算

    Java位运算是一种在计算机科学中广泛使用的操作,它涉及到对二进制位的直接操作,包括按位与、按位或、按位异或、按位非、左移、右移以及无符号右移等。这些操作对于理解底层计算原理、优化代码性能以及在特定场景下...

    java位运算,符号运算 详细解释

    Java位运算是一种底层操作,它直接作用于二进制位,是计算机科学中的基础操作。在Java编程中,位运算可以用于高效地处理数据,尤其是在处理数组、位集或者进行低级优化时非常有用。本篇文章将深入探讨Java中的位运算...

    20191220-Java位运算_java_位运算_

    Java位运算在编程中是一种非常基础且强大的操作,它直接作用于二进制位,能够进行高效的数值处理和数据操作。本文将深入讲解Java中的位运算,并通过雪花算法的应用实例来进一步阐述其重要性和用法。 1. **位运算...

    java位运算大全.pdf

    Java位运算大全涵盖了Java中位运算的基本概念、运算符以及其应用。位运算是一种直接对整数型数据的二进制位进行操作的运算,它可以用于高效地处理数据,尤其在系统底层开发和算法设计中至关重要。 首先,位运算的...

    java 位运算知识

    Java 位运算是编程语言中的一种底层操作,它允许我们直接对整数类型的数据进行按位操作,包括按位与(&)、按位或(|)、按位异或(^)、按位非(~)以及左移()、右移(&gt;&gt;)和无符号右移&gt;&gt;&gt;。这些操作在处理二进制数据、优化...

    java 位运算,代码简单,易懂,大量注释

    简单的Java位运算,代码简单,易懂,大量注释

    java位运算大全.doc

    Java中的位运算是一种高效的操作,它是直接针对二进制位进行操作,因此在处理特定问题,如加密算法和图形算法时,位运算可以提供较高的性能。在Java中,位运算符包括右移(&gt;&gt;&gt;),左移(),无符号右移(&gt;&gt;),按位与(&),按位...

    Java位运算的应用

    Java中的位运算是一种高效的操作方式,它可以直接对二进制数据进行操作,广泛应用于各种算法和数据处理中。本文将详细介绍这些位运算的应用,并通过具体的例子来解释它们的工作原理。 1. **奇偶数判断**:`a&1`可以...

    位运算课件(java学习位运算课件)

    位运算在Java编程中是底层操作,用于直接处理二进制数据,对于理解计算机内部机制和优化代码性能至关重要。本文将深入探讨位运算的相关知识,包括计算机中数据的表示方法、二进制计数系统、以及原码、反码和补码的...

    Java位操作工具类

    经常项目中用到的Java的位运算相关的方法,稍微整理了下 详细介绍可参考博客 http://longshaojian.iteye.com/admin/blogs/1946865 请多指教!

    Java 中的位运算

    ### Java中的位运算知识点 #### 一、位运算概述 位运算是计算机科学中的一个基本概念,它直接针对二进制位进行操作。在Java语言中,提供了多种位运算符来处理二进制数据,这对于优化算法性能、提高程序效率等方面...

    Java位运算和逻辑运算的区别实例

    在Java编程语言中,位运算和逻辑运算都用于处理布尔值和整数,但它们在实际操作和行为上有着显著的差异。理解这些差异对于优化代码和深入理解计算机底层工作原理至关重要。 首先,我们来看看逻辑运算符。逻辑运算符...

    java位运算1.pdf

    Java中的位运算是一种底层操作,它直接作用于二进制数据,可以用于高效地处理整数,尤其是在内存有限或者需要高性能计算的场景中。本文主要介绍Java中的位运算及其应用场景。 1. **位运算的表示方法** - Java中...

Global site tag (gtag.js) - Google Analytics