位运算逻辑运算符包括: 与(&),非(~),或(|),异或(^).

  • &:  条件1&条件2  ,只有条件1和条件2都满足, 整个表达式才为真true,  只要有1个为false,整个表达式就为假false
  • 如果条件1为假false, 条件2仍旧需要判断
  • 除了用于逻辑条件以外,还可以做数字之间的按位与
  • &&:  条件1&条件2  ,只有条件1和条件2都满足, 整个表达式才为真true,  只要有1个为false,整个表达式就为假false
  • 如果条件1为假false, 条件2不需要判断
  • |:  条件1 | 条件2  ,只要有一个条件为真true,整个表达式就为真true , 如果2个条件都为假,整个表达式才为假false
  • 如果条件1为真,条件2仍旧需要判断
  • 除了用于逻辑条件以外,还可以做数字之间的按位或
  • ||:  条件1 || 条件2  ,只要有一个条件为真true,整个表达式就为真true , 如果2个条件都为假,整个表达式才为假false
  • 如果条件1为真,条件2不需要判断


    • ^: 按位异或. 参与运算的两个值,如果两个相应位相同,则结果为0,否则为1.
    • 0异或任何数等于任何数, 1异或任何数等于任何数取反, 任何数异或自己等于把自己置0

     ~: 按位取反. 0变1,1变0.   负数在内存中的表现是, 按位取反再加1.

通过按位异或运算,可以实现两个值的交换,而不必使用临时变量.

public class Demo3 {
public static void main(String[] args) {
/** 数a两次异或同一个数b(a=a^b^b)仍然为原值.*/
int a = 100;
int b = 666; a = a ^ b;
b = b ^ a;
a = a ^ b; System.out.println("a: " + a + " b " + b);
}
}

可用异或进行加密


&: 与. 当两边操作数的位同时为1时, 结果为1, 否则为0.

位运算判断奇偶, 偶数的最低位是0,奇数的最低位是1.通过这个原理, 我们可以根据整数二进制最后一位与1比较, 判断奇偶.
public class Demo2 {
public static void main(String[] args) {
/** 随机一个整数*/
int a = new Random().nextInt();
/** 判断奇偶性*/
String numStr = ((a & 1) == 1) ? "奇数" : "偶数";
System.out.println("随机数为: " + a + " 是: " + numStr);
}
}


java移位运算符包括:

    • <<:左移位
    • >>:带符号右移
    • >>>:无符号右移

都是相对于二进制的补码来进行移动的

在Java语言中, 二进制数使用补码表示, 最高位为符号位, 正数的符号位为0, 负数为1.

补码的表示规则:

    • 正数的最高位为0,其余各位代表数值本身(二进制数).
    • 对于负数,通过对该数绝对值的补码按位取反,再对整个数加1.

java位运算,逻辑运算符的更多相关文章

  1. Java 位运算2-LeetCode 201 Bitwise AND of Numbers Range

    在Java位运算总结-leetcode题目博文中总结了Java提供的按位运算操作符,今天又碰到LeetCode中一道按位操作的题目 Given a range [m, n] where 0 <= ...

  2. Java位运算总结:位运算用途广泛《转》

    前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...

  3. Java位运算原理及使用讲解

    前言日常开发中位运算不是很常用,但是巧妙的使用位运算可以大量减少运行开销,优化算法.举个例子,翻转操作比较常见,比如初始值为1,操作一次变为0,再操作一次变为1.可能的做法是使用三木运算符,判断原始值 ...

  4. (转)java位运算

    转自:http://aijuans.iteye.com/blog/1850655 Java 位运算(移位.位与.或.异或.非)   public class Test { public static ...

  5. Java位运算总结:位运算用途广泛

    前天几天研究了下JDK的Collection接口,本来准备接着研究Map接口,可是一查看HashMap类源码傻眼咯,到处是位运算实现,所以我觉得还是有必要先补补位运算知识,不然代码看起来有点费力.今天 ...

  6. Java 位运算超全面总结

    1.原码.反码.补码 关于原码.反码.补码的相关知识作者不打算在这里长篇大论,相关知识已有别的大佬总结很好了,还请老铁自行 Google,不过有篇知乎回答是作者学编程以来见过对相关知识最通俗易懂,生动 ...

  7. 我们必须要了解的Java位运算(不仅限于Java)

    本文原创地址为 https://www.cnblogs.com/zh94/p/16195373.html 原创声明:作者:陈咬金. 博客地址:https://www.cnblogs.com/zh94/ ...

  8. Java位运算经典实例

    一 源码.反码.补码 正数的源码.反码.补码相同,例如5:            5的源码:101            5的反码:101            5的补码:101 负数的源码.反码.补 ...

  9. Java 位运算(移位、位与、或、异或、非)

    Java提供的位运算符有:左移( << ).右移( >> ) .无符号右移( >>> ) .位与( & ) .位或( | ).位非( ~ ).位异或( ...

随机推荐

  1. kafka 主题管理

    对于 kafka 主题(topic)的管理(增删改查),使用最多的便是kafka自带的脚本. 创建主题 kafka提供了自带的 kafka-topics 脚本,用来帮助用户创建主题(topic). b ...

  2. javascript实现二叉搜索树

    在使用javascript实现基本的数据结构中,练习了好几周,对基本的数据结构如 栈.队列.链表.集合.哈希表.树.图等内容进行了总结并且写了笔记和代码. 在 github中可以看到  点击查看,可以 ...

  3. HBase常用操作之namespace

    1.介绍 在HBase中,namespace命名空间指对一组表的逻辑分组,类似RDBMS中的database,方便对表在业务上划分.Apache HBase从0.98.0, 0.95.2两个版本开始支 ...

  4. Elastic Stack 笔记(七)Elasticsearch5.6 聚合分析

    博客地址:http://www.moonxy.com 一.前言 Elasticsearch 是一个分布式的全文搜索引擎,索引和搜索是 Elasticsarch 的基本功能.同时,Elasticsear ...

  5. day 3 总结

  6. js屏蔽地区

    其实不需要后台代码也可以获取地区信息的,就算是后台代码,也得需要引用一些第三方库提供免费的api接口才可以,最后还是反序列化才能得到想要的数据,那干嘛不直接找,提供好json格式的api接口,拿来js ...

  7. Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000fa980000, 59244544, 0) failed; error='Cannot allocate memory' (errno=12)

    启动项目报错 Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000fa980000, 592445 ...

  8. redis实现网关限流(限制API调用次数1000次/分)

    添加maven依赖,使用springboot2.x版本 <dependency> <groupId>org.springframework.boot</groupId&g ...

  9. 2018年蓝桥杯java b组第四题

    标题:测试次数 x星球的居民脾气不太好,但好在他们生气的时候唯一的异常举动是:摔手机.各大厂商也就纷纷推出各种耐摔型手机.x星球的质监局规定了手机必须经过耐摔测试,并且评定出一个耐摔指数来,之后才允许 ...

  10. Spring boot集成Rabbit MQ使用初体验

    Spring boot集成Rabbit MQ使用初体验 1.rabbit mq基本特性 首先介绍一下rabbitMQ的几个特性 Asynchronous Messaging Supports mult ...