关于JAVA中Byte数据类型二进制赋值运算报错问题
自从JDK7更新之后,新增了二进制变量的表示,支持将整数类型用二进制来表示,用0b开头;
例如: byte b= (byte) 0b1000_0001;
short s = (short) 0b1000_0000_0000_0001;
新手在这个时候会遇到一个问题,为啥byte b=0b100_00001会报错(cannot convert from int to byte)
而short b=0b100_00001又不会呢?既然java底层默认0b100_00001是int类型,为什么short可以呢?
有的人说是byte是字节数据类型,short是短整数据类型,个人认为不太准确。所以我们在做个试验:
试验1:short b=0b100_00001;//正常赋值;
short s=0b1000_0000_0000_0001;//系统报错(cannot convert from int to byte);
这个结果出来想必大家都有些眉目了,在二进制中最高位被定义为符号位,byte共有8个比特位,我们给它
0b000_0001时,最高位系统无法判断是 实际数值 还是 符号位数值 。如果我们加上(byte),则系统认为
此时的0是符号位,可以赋值;如果没有加(byte),则认为是实际数值,然而byte类型只有8个比特位,无位置
表示符号位,因此溢出报错。
试验2:byte b=0b0000_0001;// 正常赋值
byte b=0b1000_0000;//报错
再次印证了上面的推理,默认最高位是实际数值,超出位宽报错。
-----------------------------------------------------------------黄金分割线---------------------------------------------------------------------
问题2:
byte a=(byte)0b1111_1111+0b0000_0001; ---> 0 //运行结果为0
有人解释道0b0000_0001为int类型,而(byte)0b1111_1111为byte类型,运算时会转为int类型运算,即为:
0000_0000_0000_0000_0000_0000_1111_1111
+
0000_0000_0000_0000_0000_0000_0000_0001
||
0000_0000_0000_0000_0000_0001_0000_0000
|| 转为byte类型,直接截取后8位
0000_0000 = 0
那么又有人问了:
int a=(byte)0b1111_1111+0b0000_0001; 0 //运行结果同样为0,为什么不是256
按照上面的意思被赋值变量a属于int类型,既然是按照int类型运算,结果就不用转换了嘛,直接赋值不就行啦?
我们在看几组试验:
1 、 byte a=(byte)0b0000_0001+0b1111_1111; -->报错 //cannot convert from int to byte
int a=(byte)0b0000_0001+0b1111_1111; -->256 正常赋值
2 、 byte a=(byte)0b1111_1111+(byte)0b0000_0001; --> 0
int a=(byte)0b1111_1111+(byte)0b0000_0001; --> 0
3、 byte a=(byte)(0b1111_1111+0b0000_0001); --> 0
int a=(byte)(0b1111_1111+0b0000_0001); --> 0
4、 int a=0b1111_1111+0b0000_0001; --> 256
第一组报错从第一个问题可以推出,0b1111_1111超出了等号左边的byte类型范围,所以才会报错。
我们有三种推断:
第一、如果是都转为byte类型进行运算,那会考虑到符号位,多余正溢出,超出位宽自然舍弃,相加结果应为0b1000_0000,结果应为-128才对
显然结果不是这样的,因此这种推断错误;
第二、如果是都转为int类型进行运算,然后把值赋值给等号左边,这种推论试验2中int a=0,说不通,因此这种推断错误;
第三、运算按照java直接值得规则,数值类型进行算数运算时,所有参与算数运算的数都会自动转换为参与运算的最大类型,得到的值也是该类型
我们一一验证补码运算的结果{(byte)0b1111_1111对应的原码为1000_0001即为-1,而0000_0001位1,相加结果为0},以上问题都可以推理出来,
因此,第三种推论是正确的,打完收工。
关于JAVA中Byte数据类型二进制赋值运算报错问题的更多相关文章
- Java中Byte类型数据在运算中的问题
比如: byte a=1; byte b=2; byte c; c=a+b; //这样是计算不出c,是错误的 c=a+1; //这样也是不能计算c的 c=64+1; //为什么这样就能计算c,在Jav ...
- Java中float浮点型变量不加F报错情况
1 public class Text { 2 3 public static void main(String args[] ){ 4 float x=123.45; 5 System.out.pr ...
- java中byte数组,二进制binary安装chunk大小读取数据
int CHUNKED_SIZE = 8000; public void recognizeText(byte[] data) throws InterruptedException, IOExcep ...
- Java中List集合转Map集合报错:Duplicate key
一.问题由来 最近生成环境刚发布了一个版本,本人负责优化的一个功能在进行测试时,报错了一个异常,duplicate key;去百度里面看了一下, 意思很明确就是建重复,而且错误是在Java代码中抛出来 ...
- Java中的List转换成JSON报错(五)
1.错误描述 Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/beanu ...
- Java中的List转换成JSON报错(四)
1.错误描述 Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/colle ...
- Java中的List转换成JSON报错(三)
1.错误描述 Exception in thread "main" java.lang.NoClassDefFoundError: net/sf/ezmorph/Morpher a ...
- Java中的List转换成JSON报错(二)
1.错误描述 Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/loggi ...
- Java中的List转换成JSON报错(一)
1.错误描述 Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/lang/ ...
随机推荐
- django中如何建立抽象型数据库作为父模块可继承其功能
先建立抽象数据库 from django.db import models class BaseModel(models.Model): """为模型类补充字段" ...
- mybatis 学习笔记(二):mybatis SQL注入问题
mybatis 学习笔记(二):mybatis SQL注入问题 SQL 注入攻击 首先了解下概念,什么叫SQL 注入: SQL注入攻击,简称SQL攻击或注入攻击,是发生于应用程序之数据库层的安全漏洞. ...
- 基于 Django 的手机管理系统
前段时间和小组一起完成数据库作业,觉得收获挺多的,分享到博客来. 一.概述 打算通过设计数据库,然后结合 Python 框架Django,实现在网页上对数据库的增删改查(本例以手机的管理为例,不考虑订 ...
- 将php命令加入cenos环境变量
0.修改/etc/profile文件使其永久性生效,并对所有系统用户生效,在文件末尾加上如下两行代码 1.PATH=$PATH:/usr/local/webserver/php/bin:/usr/lo ...
- Android Gradle 隐形依赖的奇怪案例
相信 Android 开发者都有在 Android Studio 中升级 compileSdkVersion 的经历,这个时候如果你使用了 support 包,并同时升级,那么可能会出现一个错误提示. ...
- P2045 方格取数加强版 最大费用最大流
$ \color{#0066ff}{ 题目描述 }$ 给出一个n*n的矩阵,每一格有一个非负整数Aij,(Aij <= 1000)现在从(1,1)出发,可以往右或者往下走,最后到达(n,n),每 ...
- Sql server 千万级大数据SQL查询优化的几点建议
1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索 ...
- Spring Eureka的使用入门--服务端与客户端
接上篇: Eureka作为注册中心,连接服务端与客户端: 服务端: 依赖包: apply plugin: 'org.springframework.boot' apply plugin: 'io.sp ...
- zoj4062 Plants vs. Zombies 二分+模拟(贪心的思维)
题目传送门 题目大意:有n个植物排成一排,标号为1-n,每株植物有自己的生长速度ai,每对植物浇一次水,该株植物就长高ai,现在机器人从第0个格子出发,每次走一步,不能停留,每一步浇一次水,总共可以走 ...
- SQL数据库查询一张表新建一个排序字段并根据某列的排序存储排序值
现在有一张表如下Id Name Age Classify Score1 张一 18 一班 122 张二 17 二班 19 3 张三 19 三班 30 我跟据他们的分数进行排名 再去新建一个列存储排序值 ...