热门标签 | 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的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了Java高并发程序设计中线程安全的概念与synchronized关键字的使用。通过一个计数器的例子,演示了多线程同时对变量进行累加操作时可能出现的问题。最终值会小于预期的原因是因为两个线程同时对变量进行写入时,其中一个线程的结果会覆盖另一个线程的结果。为了解决这个问题,可以使用synchronized关键字来保证线程安全。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
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社区 版权所有