java 基本类型详解 及 常见问题
鄙人不才,基础不好,趁着闲时简单学习一下,仅作学习分享,如有不正确地方还请各位看客不吝指出。
常用的基本类型有:byte(8)、short(16)、char(16,取值从0-65535[2^16-1])、int(32)、long(64)、float(32)、double(64)、boolean(true/false).
注:关于boolean的长度的问题csdn的论坛中有讨论:http://bbs.csdn.net/topics/190122943
,有兴趣可以去看一下.
这个问题和String s = "a"产生几个对象类型,很多时候和JVM相关。(我看的时候本来感觉懂了,看着看着就晕了)
具体做一下简单分类:
字符型:char
布尔型:boolean
数值型(细分为两类)
整值型:byte、short、int、long
浮点型:float、double
每个类型的长度不做详述了,可以通过(2^+-n)-1进行计算,char特别一点已指出。
对基本类型的基本操作符不做详解,但以下问题可以稍作了解:
移位操作(<<,>>,>>>)
移位操作符操作可对byte、short、char、int、long。
计算过程中byte,short,char会自动转换为int类型进行计算。因此不能把计算将结果直接赋值回原有类型。
当然可以进行强转,但不推荐。
例如:char c = (char)('a'<<17);-->char c = (char)(12713984);-->最终得到的c值为0对于的字符。
int类型操作结果为int类型。long操作结果为long。
移位操作有周期性,int周期为32(1<<32 = 1),long周期为64(1L<<64 = 1L)
溢出问题
计算过程中计算数值可能会存在超出类型最大/小值的情况。此时不会报错,但是计算结果就是错了。
此类问题可以采用更高精度类型或BigInteger、BigDecimal进行解决。
例如:
int i = Integer.MAX_VALUE;//2147483647
int x = i + i;
此时,x的值却不是4294967294 而是 -2.
还有一种情况,强制转换也会导致精度损失
例如:
int a = 1234567890;
float f = a;
int 可以向同为32位的float转换,但由于float不可能精确到9个有效位,因此精度会有损失.
关于小数位精度问题
经常会遇到 double d = 2.0-1.1;的问题,这里讲一下为什么得到的结果不是0.9?
众所周知,计算机采用二进制进行数据存储。2.0 即2表示为二进制为 10
1.1用二进制表示分为两个部分1和0.1
1 = 1
0.1的采用乘2取整法计算
0.1*2=0.2 ... 0
0.2*2=0.4 ... 0
0.4*2=0.8 ... 0
0.8*2=1.6 ... 1 ... 0.6
0.6*2=1.2 ... 1 ... 0.2
0.2*2=0.4 ... 0
0.4*2=0.8 ... 0
0.8*2=1.6 ... 1 ... 0.6
0.6*2=1.2 ... 1 ... 0.2
0.2*2=0.4 ... 0
0.4*2=0.8 ... 0
0.8*2=1.6 ... 1 ... 0.6
0.6*2=1.2 ... 1 ... 0.2
.....循环了
1.1 = 1.00011001100110011001100110011.....
但是double的长度有限制,因此部分精度会被截断。因此不能精确进行计算。
结论:需要精确计算的时候使用BigDecimal吧.
java中,float类型的变量只有7位的精度,而double类型的变量有15位的精度。
如果超出范围就会造成精度丢失,原因是十进制数的二进制表示可能不够精确,因为计算机会先把这个数字转换成2进制,
就是0101那种,超出的部分会被截取,导致出现这种数据。
关于舍入问题
这个问题一般与需求有关。
new BigDecimal(0.1234567890).setScale(4,取舍方式).doubleValue();
取舍方式提供:
BigDecimal.ROUND_HALF_UP 四舍五入
BigDecimal.ROUND_HALF_DOWN 五舍六入
BigDecimal.ROUND_HALF_EVEN 四舍六入五取偶
额,基本就这样了,如有不足请补充.
java 基本类型详解 及 常见问题的更多相关文章
- JAVA集合类型详解
一.前言 作为java面试的常客[集合类型]是永恒的话题:在开发中,主要了解具体的使用,没有太多的去关注具体的理论说明,掌握那几种常用的集合类型貌似也就够使用了:导致这一些集合类型的理论有可能经常的忘 ...
- java枚举类型详解
枚举类型是JDK1.5的新特性.显然,enum很像特殊的class,实际上enum声明定义的类型就是一个类.而这些类都是类库中Enum类的子类(java.lang.Enum<E>).它 ...
- Java字符串类型详解
Java 字符串类主要有String.StringBuffer.StringBuilder.StringTokenizer 1.字符串类型底层都是使用char数组进行实现. 2.从jdk1.7以后,S ...
- Java虚拟机详解----JVM常见问题总结
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- Java 字符串格式化详解
Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...
- Java 序列化Serializable详解
Java 序列化Serializable详解(附详细例子) Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连 ...
- Java String类详解
Java String类详解 Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,很多时候,我们对它既熟悉又陌生. 类结构: public final ...
- Java 序列化Serializable详解(附详细例子)
Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化 Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization ...
- Java类加载器详解
title: Java类加载器详解date: 2015-10-20 18:16:52tags: JVM--- ## JVM三种类型的类加载器- 我们首先看一下JVM预定义的三种类型类加载器,当一个 J ...
随机推荐
- html5学习之路_005
PHP环境搭建 1.下载安装xampp 2.打开xampp,开启mysql和apache 3.在开发环境eclips中下载插件 4.安装php 5.切换到php开发环境 6.创建一个php项目 7.打 ...
- GitHub的raw.githubusercontent.com无法链接
今天在用Github下载是总报错,其中错误一开始是DNS的问题 查资料后得知是DNS污染,之后就先找真实的IP地址,添加进C:\Windows\System32\drivers\etc hosts文件 ...
- 08 . Python3高阶函数之迭代器、装饰器
Python3高阶函数之迭代器.装饰器 列表生成式 推导式就是构建比较有规律的列表,生成器. 孩子,我现在有个需求,看列表[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],我要求你把列表里 ...
- python通用数据库操作工具 pydbclib
pydbclib是一个通用的python关系型数据库操作工具包,使用统一的接口操作各种关系型数据库(如 oracle.mysql.postgres.hive.impala等)进行增删改查,它是对各个p ...
- VNC CentOS 7 远程工具,VNC CentOS 7 远程工具推荐!
IIS7服务器管理工具是一款能够在Windows和Linux系统下进行VNC使用的软件!它能够成为VNC的客户端,帮助操作者完成VNC的相关命令!同时,它还能够作为FTP的操作客户端,实现FTP的传输 ...
- Chisel3 - 字面量(literal)
https://mp.weixin.qq.com/s/uiW4k4DeguvYsG8LhHk2Ug 介绍Chisel3中基本数据类型的字面量的写法,及其背后的实现机制,也就是Scala隐式规则. ...
- Java实现 LeetCode 719 找出第 k 小的距离对(二分搜索法+二分猜数字)
719. 找出第 k 小的距离对 给定一个整数数组,返回所有数对之间的第 k 个最小距离.一对 (A, B) 的距离被定义为 A 和 B 之间的绝对差值. 示例 1: 输入: nums = [1,3, ...
- Java实现 LeetCode 547 朋友圈(并查集?)
547. 朋友圈 班上有 N 名学生.其中有些人是朋友,有些则不是.他们的友谊具有是传递性.如果已知 A 是 B 的朋友,B 是 C 的朋友,那么我们可以认为 A 也是 C 的朋友.所谓的朋友圈,是指 ...
- Java实现 LeetCode 43 字符串相乘
43. 字符串相乘 给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式. 示例 1: 输入: num1 = "2& ...
- java实现第四届蓝桥杯猜年龄
猜年龄 题目描述 美国数学家维纳(N.Wiener)智力早熟,11岁就上了大学.他曾在1935~1936年应邀来中国清华大学讲学. 一次,他参加某个重要会议,年轻的脸孔引人注目.于是有人询问他的年龄, ...