详述Java基本数据类型

在程序中往往需要存放许多数据,每个数据所占内存各不相同,给多了太浪费,给少了更不行。而且不同类型的数据,有一些存放方式也不同,所以我们需要定义数据的类型。

数据类型决定了内存中存储数据的类型及所需内存的大小

Java的数据类型可分为两大类:

-基本数据类型:byteshortintlongdoublefloatbooleanchar

-引用数据类型:类、接口、数组、枚举、注解

今天我们主要讲解一下基本数据类型。

 我们先来看一下这些基本数据所占字节,位数和一些说明,如下图

这里说一下为什么int型和float型都是四个字节但是取值范围差这么多

int4字节32位,第一个位置是符号位,其他按二进制存放数据最大为2的32次方-1

float同样也是4字节保存只不过他的保存形式式如下:

也就是说第一个位置是符号位,如果它为0表示正数,为1表示负数
第2-9位共8个位是指数位,这里的指数位使用的是带偏阶的计数法1,就是说,这里存储的指数 = 真正指数+127,这里的127是它的偏阶。那么它最大能够存储多大的指数呢,8位最多能表示28−1 2^{8}-12 
8
 −1个数字也就是255个数字,从全0(0)到全1(255)。但是IEEE754的指数全1是不能表示数字的;真正指数 = 这里存的指数-127,所以最大能够存储的指数是254-127 = 127,最小能够存储的指数是1-127 = -126,这里最小用了1减,而没有用0,是因为当指数为0,而尾数非0,这不是规格化数。所以最终指数部分能够表示的范围是-126 ~ 127
在看尾数部分,IEEE754隐藏了一个前导1,也就是说,这里存储的尾数 = 真正尾数 - 1,所以我们在将存储的数据还原为原先的数据时一定要加上1.

接下来我们来讲解基本数据类型

整型是用来定义整数的关键字,四种整型(byteshortintlong)都有其表示范围。

Java整形数据类型的有如下4种表示形式:

              十进制整数,例如12-127,0

              二进制整数,以0b开头,例如0b011 (对应于十进制的3 ) (JDK7.0开始)。

              八进制整数,以0开头,例如014(对应于十进制的12)。

              十六进制整数,以0x0X开头,例如0XF(对应于十进制的15)。

注意:

         由于不同整型数据类型在内存中分配的大小不一样,所以我们在开发中到底使用哪种数据类型要慎重思考,这关系到程序的性能,比如人的年龄不会超过200岁,所以选择short比较合适。选择浮点型的时候也应如此。

浮点型是用来定义小数的关键字。

浮点型数据有如下两种表示方式:

             十进制形式,例如3.14

             科学计数法形式,例如3.14e1

注意:

             float f = 1.3;是错误的,1.3默认是double型的。在对float数据进行赋值时,要在数字的后面添加f(或F),否则Java编译器会认为1.3是一个double类型的数值,而double不能直接赋值给float类型,故:正确赋值方式应为float f1 = 1.3f;

      布尔型,又称逻辑类型,只有truefalse两个取值,默认初始值为false。这区别与C语言,在C语言标准(C89)没有定义布尔类型,所以C语言判断真假时以0为假,非0为真。

注意:    在二进制逻辑Java规定1为真0为假。

 

字符型采用Unicode编码,一个Unicode编码占2个字节(即16位),由于字符型不存在正负之分,所以其表示范围为0216次方-1065535)。

该种数据类型的变量可以有以下几种赋值方式:

使用英文单引号(')括起单个字符;例如:

   char c1 = 'a';

   char c2 = '';//char可以存储一个中文(一个中文也占2个字节)

使用英文单引号括起来十六进制字符代码值来表示单个字符,格式为'\uXXXX',其中u是约定的前缀,为Unicode的第一个字母,例如:

   char c1 ='\u0061';// 实质代表a字母

可以直接使用数字表示单个字符,例如:

   char c2 = 97;//表示a字母

某些特殊的字符可以采用转义符'\'来表示,以将其后面的字符转变为其它含义,例如:

   char c1 = '\t';//制表符

   char c2 = '\n';//换行符-New Line

   char c3 = '\r';//回车符-Carriage Return

以上就是Java中基本数据类型的一些说明。

下面我将补充说明一下Java基本类型之间的相互转换

Java数据类型转换(无论是基本数据类型还是引用类型)分为:

      自动类型转换

      强制类型转换

将表示范围小的数据类型赋值给表示范围大的数据类型时,Java自动使用隐式类型完成数据类型转换,即:

      低-------------------------------------------------------------------------------------------------------------------------->

      byte  ------------>  short/char  ------------>  int  ------------>  long  ------------>  float  ------------>  double

当把级别高的变量赋值给级别低的变量时,必须使用显式类型转换。显示转换格式:(要转换的类型)被转换的值。

int x=(int)23.89;//x的值为23

long y=(long)34.98F; ;//y的值为34

byte z = (byte)256;//z的值为0,数据结果出现溢出

注意:

             显式类型转化(强制类型转换)可能导致数据精度损失或溢出

大家在进行类型转换时要注意两种类型的取值范围,不到导致重要数据的缺失。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值