先举三个栗子:

1.

public static void main(String[] args) {
Double d = new Double(123.56); byte b = d.byteValue(); System.out.println(b);
}

输出结果:123

2.

public static void main(String[] args) {
Double d = new Double(456.56); byte b = d.byteValue(); System.out.println(b);
}

输出结果:-56

3.

public static void main(String[] args) {
Double d = new Double(567.56); byte b = d.byteValue(); System.out.println(b);
}

输出结果:55

大家应该看出来了吧,这三个只是Double的整数位变化了,但输出结果却差不少,而且一眼是看不出来规律的

原因解析:1.翻源码,看看byteValue()是咋处理的

上源码:

/**
* Returns the value of this {@code Double} as a {@code byte}
* after a narrowing primitive conversion.
*
* @return the {@code double} value represented by this object
* converted to type {@code byte}
* @jls 5.1.3 Narrowing Primitive Conversions
* @since JDK1.1
*/
public byte byteValue() {
return (byte)value;
}

惊不惊喜!意不意外!没错,就是强转了

2.Double强转byte时的操作过程

记住这句话:正整数在计算机中用原码来表示的,而负整数在计算机中用补码来表示的

1  取整

2  整数部分与[256]取模

3.1 如果该整数在[-128,127]之间,直接打印

3.2 如果该整数在[-128,127]之外,将这个值化为二进制,判断第一位是1还是0

  3.2.1   如果是1,表明该数为一个负数

  3.2.2   如果是0,表明该数为一个正数

好了,概念说完了,回头理解一下最开始举的栗子

先说第一个:

123.45  -->  取整  123  -->  整数部分与[256]取模  123  -->  在[-128,127]区间内  -->  打印输出

第一个最简单了,很容易理解,接下来讲第三个

注意啊,是第三个(因为第二个比较难,放在最后讲)

567.56  -->  取整  567  -->  整数部分与[256]取模  55  -->  在[-128,127]区间内  -->  打印输出

看,其实第一个和第三个是同样原理,接下来分析第二个

456.56  -->  取整  456  -->  整数部分与[256]取模  200  -->  在[-128,127]区间外

在区间外,所以我们将 200 转为二进制来看

200二进制为 ‭1100 1000‬

第一位为1,也就是说这个数是个负数,还记得上面标粗体的让记住的那就话了么

记住这句话:正整数在计算机中用原码来表示的,而负整数在计算机中用补码来表示的

所以,这个 1100 1000‬ 其实存的是一个补码,我们根据补码算出原码

计算法则:

补码的补码就是原码

二、负整数的符号位固定为1,由原码变为补码时,规则如下:

      1、原码符号位1不变,整数的每一位二进制数位求反,得到反码

  1011 0111

      2、反码符号位1不变,反码数值位最低位加1,得到补码

  1011 1000

根据此数求出十进制的值

1*2^3 + 1*2^4 + 1*2^5 = 8 + 16 + 32 = 56

由于第一位为1,结果为负,即 -56

Double如果是负数也同样适用

声明:本文中未加粗的斜体摘自百度经验,其他原创手打,如需转载,请联系我本人

byte在计算机中的存储方式--Double.byteValue()的输出结果思考的更多相关文章

  1. java 20 - 8 字节流的文件复制以及汉字在计算机中的存储方式

    复制文本文件:把当前目录下的FileIntputStream.java文件里面的内容复制到当前目录的b.txt文件中 分析: 数据源: FileIntputStream.java -- 读取数据 -- ...

  2. C语言中浮点数在内存中的存储方式

    关于多字节数据类型在内存中的存储问题 //////////////////////////////////////////////////////////////// int ,short 各自是4. ...

  3. <转载>浅谈C/C++的浮点数在内存中的存储方式

    C/C++浮点数在内存中的存储方式 任何数据在内存中都是以二进制的形式存储的,例如一个short型数据1156,其二进制表示形式为00000100 10000100.则在Intel CPU架构的系统中 ...

  4. QList介绍(QList比QVector更快,这是由它们在内存中的存储方式决定的。QStringList是在QList的基础上针对字符串提供额外的函数。at()操作比操作符[]更快,因为它不需要深度复制)非常实用

    FROM:http://apps.hi.baidu.com/share/detail/33517814 今天做项目时,需要用到QList来存储一组点.为此,我对QList类的说明进行了如下翻译. QL ...

  5. Float在内存中的存储方式及IEC61131处理

    Float在内存中的存储方式及IEC61131处理 1,fp32(32bits float)类型数据在存储器中占用4Bytes存储,且遵循IEEE-754标准: 一个浮点数分三部分组成: 符号位s(1 ...

  6. YbSoftwareFactory 代码生成插件【二十五】:Razor视图中以全局方式调用后台方法输出页面代码的三种方法

    上一篇介绍了 MVC中实现动态自定义路由 的实现,本篇将介绍Razor视图中以全局方式调用后台方法输出页面代码的三种方法. 框架最新的升级实现了一个页面部件功能,其实就是通过后台方法查询数据库内容,把 ...

  7. float和double在内存中的存储方式

    本文转载于:http://wenku.baidu.com/link?url=ARfMiXVHCwCZJcqfA1gfeVkMOj9RkLlR9fIexbgs9gDdV8rIS48A1_xe1y6YgX ...

  8. C语言 float、double数据在内存中的存储方式

    float在内存中占4个字节(32bit),32bit=符号位(1bit)+指数位(8bit)+底数位(23bit) 指数部分 指数位占8bit,可以表示数值的范围是0-(表示0~255一共256个数 ...

  9. C/C++浮点数在内存中的存储方式

    一.内存表示 任何数据在内存中都是以二进制的形式存储的,浮点数的表示是把一个数的有效数字和数的范围在计算机的一个存储单元中分别予以表示,数的小数点位置随比例因子的不同而在一定范围内自由浮动.如下图是3 ...

随机推荐

  1. Windows下安装TensorFlow

    最近学习TensorFlow,当然前提是装好框架,网上教程很多都是虚拟搭建或者是conda,从我的经验来讲,Windows目前只支持Python3.5版本安装,Python官网上有说明: 本人由于常用 ...

  2. 邮箱&&密码验证-原理

    原理版: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  3. git下载Ardupilot源码

    pwd #确定当前目录 mkdir Copter-3.5.4 #如有需要,新建目录 cd Copter-3.5.4 #进入新目录文件 #克隆指定分支,并且克隆分支对应的git子模块 git clone ...

  4. 前端dom元素的操作优化建议

    参考自:http://blog.csdn.net/xuexiaodong009/article/details/51810252 其实在web开发中,单纯因为js导致性能问题的很少,主要都是因为DOM ...

  5. 什么是DOM,DOM level 1\2\3 的区别是什么

    DOM 文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标志语言的标准编程接口.Document Object Model的历史可以追溯至1990年 ...

  6. java实现单链表的增删功能

    JAVA 实现单链表的增删功能 package linked; class LinkedTable{ } public class LinkedTableTest { public static vo ...

  7. windows上SSH服务连接远程主机失败

    putty连接出现错误提示"Network error:connection refused",xshell连接出现错误提示"connection failed:(por ...

  8. [poj2585]Window Pains_拓扑排序

    Window Pains poj-2585 题目大意:给出一个4*4的方格表,由9种数字组成.其中,每一种数字只会出现在特定的位置,后出现的数字会覆盖之前在当前方格表内出现的.询问当前给出的方格表是否 ...

  9. 设计模式之 观察者模式详解(包含观察者模式JDK的漏洞以及事件驱动模型)

    作者:zuoxiaolong8810(左潇龙),转载请注明出处,特别说明:本博文来自博主原博客,为保证新博客中博文的完整性,特复制到此留存,如需转载请注明新博客地址即可. 本章我们讨论一个除前面的单例 ...

  10. bootstrap-table分页数据前台不显示

    问题:后台返回数据{"total":52,"rows":[{"ztname":"2007年新会计准则科目(李相)",&q ...