热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java中gt与gtgt与gtgtgt与lt之间的区别

本文介绍了在Java中gt、gtgt、gtgtgt和lt之间的区别。通过解释符号的含义和使用例子,帮助读者理解这些符号在二进制表示和移位操作中的作用。同时,文章还提到了负数的补码表示和移位操作的限制。

1. 今天在刷剑指,遇到一道题:

 

**输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。**

看到一个使用逻辑移位的放大进行的操作,很受启发,顺便整理一下从未用到的符号含义。

2. 符号之间的区别 


符号含义正数负数
>普通的大于等于号\\
>>带符号右移正数右移高位补0负数右移高位补1
<<带符号左移左移后面用0补左移后面用0补齐
>>>无符号右移高位通通补0高位通通补0

 

 

3. 说到这里&#xff0c;相比懂的人已经看懂了&#xff0c;如果较为新手&#xff0c;则会有些懵逼&#xff0c;那么我们来举几个简单的例子.

4 >2 &#xff1a;我就写这玩玩&#xff0c;不懂就算了

  • >>(带符号右移&#xff0c;由于符号的限制实际位数跟数据相关)

 

4 >>1 &#xff1a;

表示4二进制表示向右移动一位&#xff0c;结果为2.

4二进制&#xff1a;100 ------> 右移一位&#xff1a;010 &#61; 2

 

-4 >>1 &#xff1a;

表示-4二进制表示向右移动一位&#xff0c;结果为-2

-4二进制&#xff08;红色表示符号位&#xff09;&#xff1a; 4的二进制表示为&#xff1a;100&#xff0c;------> -4补码表示&#xff08;取反加1&#xff09;&#xff1a;1100------>右移一位&#xff08;补1&#xff09;:  1110 &#61; -2

 

>>>(无符号右移,int默认是32位)

2 >>1 &#xff1a;

表示4二进制表示向右移动一位&#xff0c;结果为2.

4二进制&#xff1a;0000 0000 0000 0000 0000 0000 0000 0010------> 右移一位&#xff1a;0000 0000 0000 0000 0000 0000 0000 0001 &#61; 1

 

-2 >>1 &#xff1a;

表示-2的32二进制表示向右移动一位&#xff0c;结果为 ${2^{31}} - 1$

-2二进制&#xff08;红色表示补全位&#xff09;&#xff1a;2的二进制表示为&#xff1a;0000 0000 0000 0000 0000 0000 0000 0010&#xff0c;------> -2补码表示&#xff08;取反加1&#xff09;&#xff1a;1111 1111 1111 1111 1111 1111 1111 1110&#xff0c; ------> 右移一位&#xff08;补0&#xff09;&#xff1a;0111 1111 1111 1111 1111 1111 1111 1111 &#61; ${2^{31}} - 1$

 

4. 说到这里&#xff0c;再来探讨一下&表示符号

    表示与的意思&#xff0c;在离散数学中&#xff0c;相同为0&#xff0c;不同为1&#xff0c;如0011与1111的&操作为&#xff1a;0011&#xff0c;很容易理解。

 

5. 在测试中遇到的问题

我们经常在java中用到 Math.pow(x, y)&#xff0c;我在测试中发现&#xff0c;运算出来竟然是小数。。。

参考了部分数据类型&#xff0c;发现是数据类型长度不满足。

变化的代码如下&#xff1a;

public class Main {public static void main(String[] args) {long a &#61; (long)Math.pow(2, 31) - 1;System.out.println(a);}
}

 

6. 再来总结一下对interger数据操作的题目&#xff0c;一般使用移位操作最为方便&#xff0c;但是一般我们接触到的比较少&#xff0c;大都不会熟练应用&#xff0c;需要多练习。另外我差的资料比较多&#xff0c;如有错误&#xff0c;麻烦指正一下&#xff0c;共同学习&#xff0c;谢谢各位皇阿玛~~~~~

 


推荐阅读
  • 本文将探讨Java编程语言中对象和类的核心概念,帮助读者更好地理解和应用面向对象编程的思想。通过实际例子和代码演示,我们将揭示如何在Java中定义、创建和使用对象。 ... [详细]
  • 异常要理解Java异常处理是如何工作的,需要掌握一下三种异常类型:检查性异常:最具代表性的检查性异常是用户错误或问题引起的异常ÿ ... [详细]
  • Java 实现二维极点算法
    本文介绍了一种使用 Java 编程语言实现的二维极点算法。该算法用于从一组二维坐标中筛选出极点,适用于需要处理几何图形和空间数据的应用场景。文章不仅详细解释了算法的工作原理,还提供了完整的代码示例。 ... [详细]
  • 深入解析Java枚举及其高级特性
    本文详细介绍了Java枚举的概念、语法、使用规则和应用场景,并探讨了其在实际编程中的高级应用。所有相关内容已收录于GitHub仓库[JavaLearningmanual](https://github.com/Ziphtracks/JavaLearningmanual),欢迎Star并持续关注。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • ------------------------------————————————————————————————1.定义一个类,实现与被增强对象相同的接口2.在类中定义一个对象,记住被增强 ... [详细]
  • 本文探讨了在Java中如何正确地将多个不同的数组插入到ArrayList中,避免所有数组在插入后变得相同的问题。我们将分析代码中的问题,并提供解决方案。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本文探讨了在C++中如何有效地清空输入缓冲区,确保程序只处理最近的输入并丢弃多余的输入。我们将介绍一种不阻塞的方法,并提供一个具体的实现方案。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 深入解析for与foreach遍历集合时的性能差异
    本文将详细探讨for循环和foreach(迭代器)在遍历集合时的性能差异,并通过实际代码示例和源码分析,帮助读者理解这两种遍历方式的不同之处。文章内容丰富且专业,旨在为编程爱好者提供有价值的参考。 ... [详细]
  • JavaScript 基础语法指南
    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 在软件开发过程中,MD5加密是一种常见的数据保护手段。本文将详细介绍如何在C#中使用两种不同的方式来实现MD5加密:字符串加密和流加密。 ... [详细]
author-avatar
低调vs完美
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有