鄙人不才,基础不好,趁着闲时简单学习一下,仅作学习分享,如有不正确地方还请各位看客不吝指出。

常用的基本类型有: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 基本类型详解 及 常见问题的更多相关文章

  1. JAVA集合类型详解

    一.前言 作为java面试的常客[集合类型]是永恒的话题:在开发中,主要了解具体的使用,没有太多的去关注具体的理论说明,掌握那几种常用的集合类型貌似也就够使用了:导致这一些集合类型的理论有可能经常的忘 ...

  2. java枚举类型详解

      枚举类型是JDK1.5的新特性.显然,enum很像特殊的class,实际上enum声明定义的类型就是一个类.而这些类都是类库中Enum类的子类(java.lang.Enum<E>).它 ...

  3. Java字符串类型详解

    Java 字符串类主要有String.StringBuffer.StringBuilder.StringTokenizer 1.字符串类型底层都是使用char数组进行实现. 2.从jdk1.7以后,S ...

  4. Java虚拟机详解----JVM常见问题总结

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  5. Java 字符串格式化详解

    Java 字符串格式化详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 文中如有纰漏,欢迎大家留言指出. 在 Java 的 String 类中,可以使用 format() 方法 ...

  6. Java 序列化Serializable详解

    Java 序列化Serializable详解(附详细例子) Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连 ...

  7. Java String类详解

    Java String类详解 Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,很多时候,我们对它既熟悉又陌生. 类结构: public final ...

  8. Java 序列化Serializable详解(附详细例子)

    Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化 Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization ...

  9. Java类加载器详解

    title: Java类加载器详解date: 2015-10-20 18:16:52tags: JVM--- ## JVM三种类型的类加载器- 我们首先看一下JVM预定义的三种类型类加载器,当一个 J ...

随机推荐

  1. [PHP自动化-进阶]002.CURL模拟登录带有验证码的网站

    引言:继前文<模拟登录并采集数据>,大家似乎看不过瘾,这会再出一发,模拟实现带验证码网站的登录. 这篇文章主要介绍了PHP使用CURL实现对带有验证码的网站进行模拟登录的方法,可以帮助读者 ...

  2. 2019-ICLR-DARTS: Differentiable Architecture Search-论文阅读

    DARTS 2019-ICLR-DARTS Differentiable Architecture Search Hanxiao Liu.Karen Simonyan.Yiming Yang GitH ...

  3. day1_计算机基础

    一.计算器5大组成:计算机硬件:(计算机是奴隶)         1.五大组成             控制器             运算器             存储器I/O:内存+外存     ...

  4. 网站的安全性对seo优化至关重要-智狐SEO顾问

    网站的安全性对seo优化至关重要    作者:智狐zhihuseo 从大的范围来看,网站安全性能也属于seo的范畴之一.域名被恶意泛解析就是网站安全性能低下的特征之一,如果网站域名被恶意泛解析,会直接 ...

  5. Take advantage of Checkra1n to Jailbreak iDevice for App analysis

    An unpatchable bootrom exploit called "checkm8" works on all iDevices up until the iPhone ...

  6. Java实现 LeetCode 621 任务调度器(暴力大法)

    621. 任务调度器 给定一个用字符数组表示的 CPU 需要执行的任务列表.其中包含使用大写的 A - Z 字母表示的26 种不同种类的任务.任务可以以任意顺序执行,并且每个任务都可以在 1 个单位时 ...

  7. Java实现 蓝桥杯 算法提高 复数四则运算

    算法提高 6-17复数四则运算 时间限制:1.0s 内存限制:512.0MB 提交此题 设计复数库,实现基本的复数加减乘除运算. 输入时只需分别键入实部和虚部,以空格分割,两个复数之间用运算符分隔:输 ...

  8. Java实现蓝桥杯 算法提高 身份证号码升级

    算法提高 身份证号码升级 时间限制:1.0s 内存限制:256.0MB 问题描述 从1999年10月1日开始,公民身份证号码由15位数字增至18位.(18位身份证号码简介).升级方法为: 1.把15位 ...

  9. Java实现 LeetCode 179 最大数

    179. 最大数 给定一组非负整数,重新排列它们的顺序使之组成一个最大的整数. 示例 1: 输入: [10,2] 输出: 210 示例 2: 输入: [3,30,34,5,9] 输出: 9534330 ...

  10. java代码(2)---Java8 Stream

    stream Java8新特性Stream流,那Stream表达式到底是什么呢,为什么可以使你的代码更加整洁而且对集合的操作效率也会大大提高? 一.概述 1.什么是Stream Stream是一种可供 ...