1. 负数为什么要用补码表示

    1. 可以将符号位和其它位统一处理
    2. 减法也可按加法来处理
    3. 另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃
  2. 正数:原码、反码、补码相同。
    负数:反码符号位不变化,其余位数取反,补码即为反码+1。
  3. 假设当前时针指向11点,而准确时间是8点,调整时间可有以下两种拨法:
        一种是倒拨3小时,即:11-3=8
        另一种是顺拨9小时:11+9=12+8=8
        在以模为12的系统中,加9和减3效果是一样的,因此凡是减3运算,都可以用加9来代替。对“模”12而言,9和3互为补数(二者相加等于模)。所以我们可以得出一个结论,即在有模的计量系统中,减一个数等于加上它的补数,从而实现将减法运算转化为加法运算的目的。
  4. 为了显示一个byte型的单字节十六进制(两位十六进制表示)的编码,请使用:

    Integer.toHexString((byteVar & 0x000000FF) | 0xFFFFFF00).substring(6)

    byteVar & 0x000000FF的作用是,如果byteVar 是负数,则会清除前面24个零,正的byte整型不受影响。(...) | 0xFFFFFF00的作用是,如果byteVar 是正数,则置前24位为一,这样toHexString输出一个小于等于15的byte整型的十六进制时,倒数第二位为零且不会被丢弃,这样可以通过substring方法进行截取最后两位即可。

  5. System.out.println(Integer.toHexString());//
    System.out.println(Integer.toHexString());//f
    System.out.println(Integer.toHexString());//
    System.out.println(Integer.valueOf("F", ));//16 //负整数时,前面输入了多余的 FF ,没有去掉前面多余的 FF,按并双字节形式输出
    System.out.println(Integer.toHexString(-).toUpperCase());//FFFFFFFE
    //实质上0xFF会像转换成0x000000FF后再进行位运算
    System.out.println(Integer.toHexString(- & 0xFF).toUpperCase());//FE
    System.out.println(Integer.toHexString(- & 0x000000FF).toUpperCase());//FE
  6. //注,FE输出时不会为-2,因为此时不会把FE看成负数,valueOf会把所有数字串看成正的
    System.out.println(Integer.valueOf("FE", ));//254
    //如果要输出-2,只能按以下形式输出
    System.out.println(Integer.valueOf("-2", ));//-2
    //所以要把 FE 看成负的话,只能在前面加上负号,但是这里输出还不是-2,
    //而是先计算Integer.valueOf("FE", 16),再在结果前加上负
    System.out.println(Integer.valueOf("-FE", ));//-254
  7. System.out.println(Integer.valueOf("-80", ));//-128
    System.out.println(Integer.valueOf("7fffffff", ));//2147483647
    //System.out.println(Integer.valueOf("80000000", 16));//不能运行,已注掉
    System.out.println(Integer.valueOf("-80000000", ));//-2147483648
  8. System.out.println(Integer.toBinaryString(-));//
    System.out.println(Integer.toBinaryString(- & 0xFF));//
    System.out.println(Integer.toBinaryString(- & 0x000000FF));//
    System.out.println(Integer.valueOf("", ));//2147483647
    //System.out.println(Integer.valueOf("10000000000000000000000000000000", 2));
    System.out.println(Integer.valueOf("-10000000000000000000000000000000", ));//-2147483648
    System.out.println(Integer.valueOf("", ));//
    System.out.println(Integer.valueOf("-11111110", ));//-254

java-整型数值 用 16进制转换、2进制转换-Integer.toHexString的更多相关文章

  1. java程序中默认整形值常量是什么类型的?如何区分不同类型的整型数值常量?

    java程序中默认整形值常量是什么类型的?如何区分不同类型的整型数值常量? 整数值默认就是int类型,只有在数值常量后面加“L”或“l”才表明该常量是long型

  2. 将int,bigint整型数值可逆转换字符串

    将 Int 和 BigInt 类型数值转换为字符串的可逆方法,可用于缩短网址或记录的ID转换等. 如: 9223372036854775807 => aZl8N0y58M7 class Conv ...

  3. Docs-.NET-C#-指南-语言参考-关键字-内置类型-值类型:整型数值类型

    ylbtech-Docs-.NET-C#-指南-语言参考-关键字-内置类型-值类型:整型数值类型 1.返回顶部 1. 整型数值类型(C# 参考) 2019/10/22 “整型数值类型”是“简单类型”的 ...

  4. 【C语言】字符串与整型数值之间的转换

    一.将字符串转化为对应的数值 /*============================================================================= # # F ...

  5. Java 字符串、数值与16进制相互转化

    字符串.数值与16进制相互转化 首先创建一个工具类: package c; public class DataUtils { /* * 字节数组转16进制字符串 */ public static St ...

  6. Java之戳中痛点 - (7)善用Java整型缓存池

    先看一段代码: package com.test; import java.util.Scanner; public class IntegerCache { public static void m ...

  7. java 整型相除得到浮点型

    public class TestFloatOrDouble { public static void main(String[] args) { Point num1 = new Point(84, ...

  8. Java整型与字符串相互转换

    >>>>>>>>>>>>>>>>>>>> 1如何将字串 String 转换成整数 ...

  9. Java整型与字符串相互转换(转)

    1如何将字串 String 转换成整数 int? A. 有两个方法: 1). int i = Integer.parseInt([String]); 或 i = Integer.parseInt([S ...

随机推荐

  1. jvm系列(四):jvm调优-命令篇

    运用jvm自带的命令可以方便的在生产监控和打印堆栈的日志信息帮忙我们来定位问题!虽然jvm调优成熟的工具已经有很多:jconsole.大名鼎鼎的VisualVM,IBM的Memory Analyzer ...

  2. F#周报2019年第35期

    新闻 新增强的NuGet搜索 Windows Terminal预览版v0.4发布 在Visual Studio的YouTube频道上获取更多的新内容 .NET团队是如何使用Azure Pipeline ...

  3. 在SpringMVC中,jsp和后台互相传值

    如题,这个是以前做的笔记,现在搬到博客上...... package com.ruide.action; ​ import java.util.HashMap; import java.util.Ma ...

  4. filter修改post参数

    前景:公司项目web渗透测试中提出管理登录时,传输密码不能为明文,需要加密传输,但是迫于系统架构,后端代码不能修改,只能在filter中解密参数. 1.前端加密处理: <script type= ...

  5. CodeForces - 697D - Puzzles DFS

    传送门:D - Puzzles 题意:在一个图中,从1开始dfs,求每一个点到达的期望: 思路:(下面是队长写的) 首先求的是到每一个点的步数的期望. 记fa( u ) = v, son( v )表示 ...

  6. CodeForces 474F Ant colony ST+二分

    Ant colony 题解: 因为一个数是合法数,那么询问区间内的其他数都要是这个数的倍数,也就是这个区间内的gcd刚好是这个数. 对于这个区间的gcd来说,不能通过前后缀来算. 所以通过ST表来询问 ...

  7. java hdu A+B for Input-Output Practice (IV)

    A+B for Input-Output Practice (IV) Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/327 ...

  8. Netty源码分析 (四)----- ChannelPipeline

    netty在服务端端口绑定和新连接建立的过程中会建立相应的channel,而与channel的动作密切相关的是pipeline这个概念,pipeline像是可以看作是一条流水线,原始的原料(字节流)进 ...

  9. sublime,webstrom,vscode的使用感受,以及对于vue和webpack的支持,还有一些快捷键使用心得

    从最开始用sublime3到webstrom再到vscode,我的感觉如下: sublime首次加载项目文件速度较快,每次装插件有点麻烦,插件很丰富,也很好用. webstrom首次加载项目文件速度奇 ...

  10. 008 Python基本语法元素小结

    目录 一.概要 二.保留字 三.温度转换 一.概要 缩进.注释.命名.变量.保留字 数据类型.字符串. 整数.浮点数.列表 赋值语句.分支语句.函数 input().print().eval(). p ...