Java的数据类型

我们知道,Java是一种强类型语言,类型对于Java语言来说非常的重要不言而喻,在Java中,分为基础数据类型引用数据类型,其中基础数据类型分为了四类八种

下面,我们来分别说一下这四类八种

整形

首先,需要说明一点,在Java的整形中不存在unsigned类型的数值,也就是说Java的整形都是有符号的可为正,可为负的整数

名称 取值范围 字节数 位数 包装类
byte \(-2^7\) 到 \(2^7-1\) 1 8 Byte
short \(-2^{15}\) 到 \(2^{15}-1\) 2 16 Short
int \(-2^{31}\) 到 \(2^{31}-1\) 4 32 Integer
long \(-2^{63}\) 到 \(2^{63}-1\) 8 64 Long

可以看出,取值范围取决于该类型的位数,由于Java的代码是运行在JVM中,所以该类型是独立于机器之外存在的,与机器的关系并没有很大,大大的提高了代码的可移植性。

在书写代码的时候,我们需要注意,在我们定义一个long类型的变量时,一定要记得在代码后加上大写的L(小写的l在某些字体下容易被认证1,给代码的可读性带来影响)。

整形默认类型

我们的整数默认类型是int类型,在我们进行计算的时候,会默认按照int类型进行计算。

byte a = 127; //right

byte b = 1; //right

byte c = a + b; // wrong

byte d = 127 + 1; //wrong

编译器报错两处,均是下面的这个错误信息:

HelloWorld.java:7: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte c = a + b; // wrong
^
HelloWorld.java:9: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte d = 127 + 1; //wrong

这是一道很常见的面试题,其中错误的原因有两点:

  • 编译器可以识别常量,但是无法识别变量,常量可以在编译期间判断是否超出范围,但是两个变量相加,编译器在编译期间无法得知,所以会报错。
  • 编译器在编译期将该值作为int类型进行预编译计算后发现超出byte的取值范围,但是又是通过一个byte类型的变量去接收,所以就会出现可能会损失精度的异常。

这里很好的体现了整数类型的默认计算类型就是int类型~

浮点类型

浮点型有两种,一种是32位的float类型(单精度),一种是64位的double类型(双精度)。

名称 取值范围 字节数 位数 包装类
float 大约\(-3.4E+38\) 到 \(+3.4E38\) 8 32 Float
double 大约\(-1.7E-308\) 到 \(1.7E308\) 16 64 Double

因为double的取值范围更广,精度更高,所以我们日常都是使用double,默认的浮点类型也是double

关于float和long

从上面我们可以知道float是32位的,而long是64位的,下意识的我们会认为64位的取值范围必定要大于32位的,但事实并非如此:

float占了4个字节,也就是32位,其中第一位是符号位,23位是尾数位,剩下的8位都是指数位,\(2^{8}\)为256,由于(signed)符号数的原因,也就是说,float的取值范围大致位于\(2^{-126}\)到\({2^{127}}\),是要远远的大于long的取值范围的。

其实,这也诠释了另外一个浮点数问题,因为计算机是二进制的,所以无法精确的表示出浮点数,但是Java也给我们了一种解决方案,那就是我们在涉及到浮点数比较敏感的地方(比如经纬度,金钱)的时候,一定要注意使用BigDecimal传参为字符串的方式!

三个特殊的浮点数值:

  1. 正无穷大(Double.POSITIVE_INFINITY)
  2. 负无穷大(Double.NEGATIVE_INFINITY)
  3. NAN(Double.NaN)

字符型

char关键字所修饰的类型是字符型,需要由单引号引起来,一个或两个char类型的数值可以表示一个Unicode字符,我们所熟知的字符串底层数据结构正是一个字符数组常量:

    /** The value is used for character storage. */
private final char value[];

char类型其实是由\u+十六进制数据的组成的,最大值为\uffff(65535),最小值为\u0000(0)

这里需要注意一些特殊的转义字符:

转义序列 名称 Unicode值
\b 退格 \u0008
\t 制表 \u0009
\n 换行 \u000a
\r 回车 \u000d
\" 双引号 \u0022
\' 单引号 \u0027
\\ 反斜杠 \u005c

布尔型

boolean修饰的变量就是布尔型,布尔类型很简单,只有true false两个值,但是这里需要注意,和C++不同的地方是它不能由数字0或1转换成布尔型

强制类型转换


byte a = 127; //right byte b = 1; //right byte c = a + b; // wrong byte d = (byte)(a + b) // right System.out.println(d);

还是这个熟悉的例子,刚刚我们已经分析了第三种情况为什么会报错,这里我们可以通过强制类型转换来强制完成这个操作。

强制类型转换只发生在位数较多的类型(int,64位)转为位数较少(byte,8位)的类型。

果不其然,我们将第三句注释掉之后,代码可以正常编译通过,然后我们去运行的时候,发现打印的d的值如下:

-128

这里就说到了强制类型转换会发生的一种情况,如果被转换的数值超出目标类型的取值范围,就会发生数据的丢失。

二进制在计算的时候,发生了超出数据范围的进位操作,随着强制类型转换,进位的部分被咔嚓掉,然后就发生这种情况了(熟悉原反补的同学应该明白这一点)。

var

JDK 10中推出了一种新的类型var,猛地看起来很像javascript中的var,它可以这么玩:

var list = new ArrayList<String>();
var x = 3;

乍一看,还真的和javascript有些像,但其实并不然,并不会影响Java是一个强类型语言的事实,它是基于局部变量推断机制来完成的,编译器在处理var时,先读构造器,并将它作为变量的类型,然后将该类型写入字节码当中。也就是说,该类型是无法更改的。

var a = 3;
a = [1,2,3];

这样的写法在javascript中毫无问题,但是在Java中就不行。但是需要注意,var只能作用于带有构造器的局部变量for循环中。

本篇重点总结

  • 数据类型四类八种
  • float取值范围要大于long
  • 强制转换只发生在高位转低位
  • var类型的原理是局部类型推断

公众号

原创文章,才疏学浅,如有不对之处,万望告知!

Java Grammer:数据类型的更多相关文章

  1. Java基础-数据类型int,short,char,long,float,double,boolean,byte

    Java语言是静态类型的(statical typed),也就是说所有变量和表达式的类型再编译时就已经完全确定.由于是statical typed,导致Java语言也是强类型(Strong typed ...

  2. Java中数据类型及其之间的转换

    Java中数据类型及其之间的转换 基本的数据类型 基本类型有以下四种:1)int长度数据类型有:byte(8bits).short(16bits).int(32bits).long(64bits).2 ...

  3. Java 基本数据类型 sizeof 功能【转】

    转自:http://blog.csdn.net/sunboy_2050/article/details/7310008 版权声明:本文为博主原创文章,未经博主允许不得转载. Java基本数据类型int ...

  4. java 的数据类型

    java 的数据类型有基本类型和引用类型 java的类的关系:有继承,有依赖,有关联,聚合,组成.

  5. java基础之java基本数据类型

    1.Java数据类型基本概念: 数据类型在计算机语言里面,是对内存位置的一个抽象表达方式,可以理解为针对内存的一种抽象的表达方式.接触每种语言的时候,都会存在数据类型的认识,有复杂的.简单的,各种数据 ...

  6. Java学习笔记之:Java的数据类型

    一.介绍 变量就是申请内存来存储值.也就是说,当创建变量的时候,需要在内存中申请空间. 内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据. Java语言提供了八种基本类型 ...

  7. Java SE ---数据类型

    Java中数据类型(Data Type)分为基本数据类型(Primitive Data Type)和引用类型(Reference Data Type). Java中的基本数据类型共有以下8种:   1 ...

  8. [未完成]关于java基础数据类型中的一些总结

    java基本数据类型转换图: 有时候也把char型成为字符型,是加上字符型也是一种特殊的整数类型.

  9. Java学习——数据类型【2】

    1. 对象与类 对象:类的一个实例,有状态和行为. 类:一个模板,描述一类对象的行状态和行为. 2. 类可以包含的变量 类型 局部变量 成员变量 类变量(静态变量) 定义位置 方法.或语句块中 类中, ...

随机推荐

  1. Linux就该这么学---第一课 20190705

    要认真学习,认真完成作业,最主要是坚持,我感觉自己坚持这个能力欠缺,要主动改正. 还想说一句,以前我是20期学员,后面没有时间学习了,现在到22期了,我要坚持学习完成,坚持 坚持 坚持!!! 现在分享 ...

  2. UVa 1440:Inspection(带下界的最小流)***

    https://vjudge.net/problem/UVA-1440 题意:给出一个图,要求每条边都必须至少走一次,问最少需要一笔画多少次. 思路:看了好久才勉强看懂模板.良心推荐:学习地址. 看完 ...

  3. js查询checkbox已选择的值

    $("input[id^=ck]").each(function(index,e){ if($(e).is(":checked")) { userArray.p ...

  4. java打印1000内的质数并用表格输出

    <table width='500' border='1'><% int c=1; for(int i=2;i<=1000;i++){ int n=0; for(int j=2 ...

  5. ASP.NET、.NET和C#的关系是怎样的?

    1..NET是什么?.Net全称.NET Framework是一个开发和运行环境,该战略是微软的一项全新创意,它将使得“互联网行业进入一个更先进的阶段”,.NET不是一种编程语言. 简单说就是一组类库 ...

  6. LinkedHashMap如何保证顺序性

    一. 前言 先看一个例子,我们想在页面展示一周内的消费变化情况,用echarts面积图进行展示.如下: 我们在后台将数据构造完成 HashMap<String, Integer> map ...

  7. C# Linq 笛卡尔积

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  8. 以Spring Cache扩展为例介绍如何进行高效的源码的阅读

    摘要 日常开发中,需要用到各种各样的框架来实现API.系统的构建.作为程序员,除了会使用框架还必须要了解框架工作的原理.这样可以便于我们排查问题,和自定义的扩展.那么如何去学习框架呢.通常我们通过阅读 ...

  9. J2EE:Servlet上传文件到服务器,并相应显示

    Servlet 可以与HTML一起使用来允许用户上传文件到服务器 编辑上传文件的页面upload.html 注意事项:上传方式使用POST不能使用GET(GET不能上传文件) 表单 enctype 属 ...

  10. python对Excel的读取

    在python自动化中,经常会遇到对数据文件的操作,比如添加多名员工,但是直接将员工数据写在python文件中,不但工作量大,要是以后再次遇到类似批量数据操作还会写在python文件中吗? 应对这一问 ...