java位运算

java位运算

位运算符分类
    java中位运算符主要有:按位与&、按位或|、按位非~、按位异或^。
 在使用时,需要将运算数都转换为二进制再进行运算,若为负数则使用补码表示

今年ccpc网络赛的第一题就是位运算。。、。

java中的位运算,涉及到计算机二进制,位用bit表示,1 byte=8bit,根据各种基本数据类型占用的字节空间,可以计算各种数据有多少位二进制,可以算出对应的取值范围

java中的位运算包括:与(&)运算,或(|)运算,亦或(^)运算,非(~)运算;以及移位运算:左移运算(<<),右移运算(>>),无符号右移运算(>>>),注意没有无符号左移运算。

1、与运算符&(and)

       与运算,两个数值进行与运算时,转换成二进制数据,两个数值中进行比对,位都为1,结果数值对应的位才为1,否则对应的位为0;

例如:5&6运算

十进制5对应的二进制为101

十进制6对应的二进制为110

运算结果为:100(二进制),则对应的十进制就是4;

2、或运算符 |(or)

      或运算,两个数值进行比对,只要有一个数值对应的位是1,则结果数值对应的位就为1,否则对应的位为0;

例如:5 | 6运算

十进制5对应的二进制为101

十进制6对应的二进制为110

与运算结果为:111(二进制),对应的十进制为7;

3、亦或运算符 ^(xor)

     亦或运算,两个数值进行比对,两个数值中,相同的位都为0或者都为1(即相同位值相同),则结果数值中对应的位则为0,不同,则结果数值中对应的位就为1;

例如:5 ^6运算

十进制5对应的二进制为101

十进制6对应的二进制为110

亦或运算之后的结果为:011,对应的十进制为3;

(注意:这里的^符号与我们平时用来做乘幂的^不同,java中不用^来做乘幂运算,java中做乘幂运算有数学函数Math.pow(x,a)来负责,表示x的a次方)

4、非运算符 ~(not)

非运算是针对单个数值来运算,数值转换成二进制后,对应的位是0,则结果数值中对应的位是1,如果位是1,则对应的结果的位是0

例如:~5

十进制5对应的二进制为101

非运算后结果为:010 ,对应的十进制为2

第二部分:移位运算

   运算符                                                             含义                      举例
     <<    左移运算符,表示将二进制数据向左移动相应的位数(在低位处补上相应位数的0)                 19<< 3
     >>    右移运算符,区别于“无符号”右移运算符,将运算符左边的十进制数值转换为二进制,然后整体向右移动运算符右边指定数的位数,使用符号拓展机制,如果值是正,则在高位补上0,反之为负,则在高位补上1                 19>>3
   >>>    “无符号”右移运算符,将运算符左边的十进制数值转为二进制后运算,二进制数据整体右移指定的位数,采用0扩展机制无论值为正负,都在高位补0               19>>>3
1、 分析左移运算

十进制19对应的二进制为10011,左移3位,原本5位的二进制,变为8位,多出的三位在低位,补0,结果为10011000,十进制数值为152,左移运算相当于原来的数值乘以2的位移位数次幂,如本例结果为19*2*2*2=152;

2、 分析有符号右移运算

十进制19对应的二进制为10011,右移3位,原本5位的二进制,变为2位(低位3位被挤掉),高位补三位,补0,结果为00010,十进制数值为2

当十进制取值为负数时,例如取值-19,则结果不同-19对应的二进制为

{补充负数二进制的获取方法:首先用-19的相反数19取二进制为10011,19的二进制10011为原码(一个整数按照绝对值大小转换成的二进制数,是为原码。32位,前面是0省略掉了),然后取反(0的变成1,1的变成0。),得到反码11111111111111111111111011101100,反码在加1为11111111111111111111111011101101得到的是补码,则-19表示为二进制就是11111111111111111111111011101101,-19右移3位,高位补1,二进制为1111111111111111111111111111101),对应十进制为-3;

 

3、分析无符号右移运算(int值占4字节,因为用的eclipse测试,是用的32位)

19>>>3,对应的十进制结果也是2

-19>>>3,-19对应的二进制为11111111111111111111111111101101,-19右移3位,高位补0,则为00011111111111111111111111111101,对应的十进制为536870909;

 

最后上一 波代码吧,部分解释来源于网络。

package fsaga;

public class gs {

	public static void main(String[] args) 
	{
		System.out.println("5&6= "+(5&6));
		System.out.println("5|6= "+(5|6));
		System.out.println("5^6= "+(5^6));
		System.out.println("19<<3= "+(19<<3));
		System.out.println("19>>3="+(19>>3));
		System.out.println("-19>>3="+(-19>>3));
		System.out.println("19>>>3="+(19>>>3));
		System.out.println("-19>>>3="+(-19>>>3));
	}

}

 

结果为:

java位运算

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114851.html原文链接:https://javaforall.net

(0)
上一篇 2021年9月29日 上午6:00
下一篇 2021年9月29日 上午7:00


相关推荐

  • Full GC触发条件总结以及解决策略「建议收藏」

    前言FullGC相对于MinorGC来说,停止用户线程的STW(stoptheworld)时间过长,至少慢10倍以上,所以要尽量避免,首先说一下FullGC可能产生的原因,接着给出排查方法以及解决策略。FullGC产生原因下图为与产生FullGC相关的内存区域,初生代、老年代、以及Metaspace区域。System.gc()方法的调用在代码中调用System…

    2022年4月12日
    219
  • python调用so文件[通俗易懂]

    python调用so文件[通俗易懂]从文章一将各个算法整合:文章(一)算法传送门:如下整合的c++代码run.cpp:源码传输门地址:https://wwi.lanzoup.com/izAEa027198d#define__USE_GNU#include<iostream>#include<cstdlib>#define__USE_GNU#include<string>#include”stdio.h”#define__USE_GNU#include”strin

    2025年12月5日
    2
  • js获取时间进行比较

    js获取时间进行比较现象 js 中获取时候进行比较方法 js 获取时间 昨天的时间 varday1 newDate day1 setTime day1 getTime 24 60 60 1000 vars1 day1 getFullYear day1 getMonth 1 day1 getDate 今天的时间 varday2 new

    2025年9月22日
    4
  • 点云数据标注_点云数据采集

    点云数据标注_点云数据采集一:什么是点云数据点云数据是指在一个三维坐标系统中的一组向量的集合。这些向量通常以X,Y,Z三维坐标的形式表示,而且一般主要用来代表一个物体的外表面形状。不经如此,除(X,Y,Z)代表的几何位置信息

    2022年8月3日
    28
  • java resourcebundle_Java ResourceBundle.getBundle如何加载属性文件?

    java resourcebundle_Java ResourceBundle.getBundle如何加载属性文件?我花了一些时间尝试加载属性文件 但找不到任何有效的解决方案 这是我的设置图片 属性文件位置 sandbox resources properties MessageBundl en US properties 应用位置 sandbox src main java com app sandbox App java 不确定发生了什么 我尝试了几种组合 但它只是无法超越异常 我甚至试过了文件夹的整个路

    2026年3月26日
    3
  • 决策树分析例题经典案例_分析模型案例解析:决策树分析法

    决策树分析例题经典案例_分析模型案例解析:决策树分析法1 1 基本概念决策树分析法又称概率分析决策方法 是指将构成决策方案的有关因素 以树状图形的方式表现出来 并据以分析和选择决策方案的一种系统分析法 它是风险型决策最常用的方法之一 特别式勇敢于分析比较复杂的问题 她以损益值为依据 比较不同方案的期望损益值 简称期望值 决定方案的取舍 其最大特点是能够形象地显示出整个决策问题在时间上和不同阶段上的决策过程 逻辑思维清晰 层次分明 非常直观 2 主要

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号