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

常用的基本类型有: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. [Objective-C] 012_数据持久化_XML属性列表,NSUserDefaults

    在日常开发中经常要对NSString.NSDictionary.NSArray.NSData.NSNumber这些基本类的数据进行持久化,我们可以用XML属性列表持久化到.plist 文件中,也可以用 ...

  2. java基础-HelloWorld

    public class HelloWorld{//源文件中只能有一类声明为public , 且类名和源文件名得一样 //main方法,程序的入口 public static void main(St ...

  3. Nuxt.js

    nuxt.js简单来说是Vue.js的通用框架,最常用的就是SSR(服务端渲染),nuxt.js这个框架,用Vue开发多页面应用,并在服务端完成渲染,可以直接用命令把我们制作的vue项目生成为静态的h ...

  4. Active MQ未授权访问

    ActiveMQ是一款流行的开源消息服务器.默认情况下,ActiveMQ服务是没有配置安全参数.恶意人员可以利用默认配置弱点发动远程命令执行攻击,获取服务器权限,从而导致数据泄露. 一.未授权访问 默 ...

  5. wavenet重要概念

    带洞因果卷积 https://img-blog.csdn.net/20181021210509222?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dl ...

  6. CentOS8的网络管理变化

    资料来源: https://www.cnblogs.com/linuxandy/p/10839856.html 1.CentOS8使用NetworkManager.service(简称NM)来管理网络 ...

  7. Java并发编程 (三) 项目准备

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.案例环境初始化 1.环境搭建与准备 Spring Boot 项目,https://start.spr ...

  8. Java实现 LeetCode 316 去除重复字母

    316. 去除重复字母 给定一个仅包含小写字母的字符串,去除字符串中重复的字母,使得每个字母只出现一次.需保证返回结果的字典序最小(要求不能打乱其他字符的相对位置). 示例 1: 输入: " ...

  9. Java实现 LeetCode 83 删除排序链表中的重复元素

    83. 删除排序链表中的重复元素 给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次. 示例 1: 输入: 1->1->2 输出: 1->2 示例 2: 输入: 1-> ...

  10. Java实现 LeetCode 6 Z字形变换

    6. Z 字形变换 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: L ...