博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java之基本数据类型
阅读量:6248 次
发布时间:2019-06-22

本文共 4570 字,大约阅读时间需要 15 分钟。

本文章分为四个部分:

1、基本数据类型的介绍

2、类型转换

3、装箱和拆箱

4、有道练习

5、增:编码的那点事儿

--------------------------------------基本数据类型的介绍--------------------------------------

Java有8种基本数据类型,其中有4种整型、2种浮点类型、1种用于表示Unicode编码的字符单元的字符类型char和1种用于表示真值的boolean类型。

类型

boolean

char

byte

short

int

long

float

double

存储需求(字节)

1

2

1

2

4

8

4

8

1、boolean类型的取值范围有两个,true和false,用来判断逻辑条件。

  并且整型值和布尔值之间不能进行相互转换。

2、char类型原本用于表示单个字符,不过现在有些Unicole字符可以用一个char值描述,另外一些Unicole字符可以用两个char值。

  char类型的字面量值要用单引号括起来。

  而且Unicode转义序列会在解析代码之前得到处理。

3、整型用于表示没有小数部分的数值,它允许是负数。

Java提供了4种整型:byte、short、int、long。

Java中是没有任何无符号(unsigned)形式的int、short、long或者byte类型的。

而且如果要表示长整形数据(long),后者要加上后缀L或者l。如果要表示二进制数,则加上前缀0B或者0b;如果要表示八进制数,则加上前缀0;如果要表示十六进制数,则加上前缀0X或者0x。

注意,byte的取值范围是:-128~127。

4、浮点类型用于表示有小数部分的数值。

在Java中有两种浮点类型 。

double表示这种类型的数据精度是float类型的两倍(双精度),绝大部分应用程序都采用double类型。

float类型的数值有一个后缀F或者f,没有后缀F的浮点数值默认为double类型。

可以用十六进制表示浮点数值。例如0.125=2-3可以表示为0x1.0p-3,在16进制表示法中,使用p表示指数,而不是e,而且尾数采用16进制,指数采用10进制。指数的基数是2,而不是10。

所有的浮点数值计算都遵循IEEE754规范,用于表示溢出和出错情况的三个特殊的浮点数值:正无穷大、负无穷大和NaN。

如果在数值计算中不允许有任何舍入误差,这个使用就应该使用BigDecimal类了。

--------------------------------------类型转换--------------------------------------

类型转换可分为两种,一种是自动类型转换、另一种是强制类型转换。

自动类型转换

  自动类型转换我们可以比拟为是“一人得道鸡犬升天”。

  假如我们在对两个数值进行二元操作,假如a是short类型的数值,b是int类型的数值,那么在进行计算的时候,a就会被转换为int类型,所以得到的结果也是int类型的数据。

sum = a+b;

  所以我们可以知道,自动类型转换的方向是从低到高的,类似于:

byte->short->int->longchar->int->longfloat->double

  在这里,可能会有一个疑问,为什么short和char要分开出来写呢?它们不都是2个字节的吗?

  原因是,short类型是有带符号的类型,也就是说它有一个符号位,但是char没有符号位,也就是说char和short类型虽然所占的内存大小一样,但是所表示的范围是不一样的(char的表示范围是0~2^16 - 1 (0 to 65535),short的表示范围是 -2^15 to 2^15 - 1 (−32,768 to 32,767))。

强制类型转换

  强制类型转换就有点像是去菜市场菜贩子会“抹零头”那样,在Java中允许进行可能会丢失一些信息的类型转换,而这种情况就需要通过强制类型转换来实现。

  强制类型转换的语法格式是在圆括号中给出想要转换的目标类型,后面紧跟待转换的变量名。如:

double d = 2.3333;int i = (int)d;

  不过如果试图将一个数值从一种类型强制转换成另一种类型,而又超出了目标类型的表示范围,结果就会截断成一个完全不同的值。

  像是不要转成boolean类型或者是byte类型。

--------------------------------------装箱和拆箱--------------------------------------

装箱和拆箱

  装箱和拆箱是一对相对的概念。

  装箱就是指把基本类型用它们相应的引用类型包装起来,使其具有对象的性质。

  拆箱就是把引用类型的对象简化成值类型的数据。

  举个栗子:

Integer i = 10; //装箱int n = i;  //拆箱

  用javap -v反编译一下就知道这两条语句对应的是不是装箱和拆箱了。

  然后我们分别看一下,Integer.valueOf方法和Integer.intValue方法的源码:

public static Integer valueOf(int i) {        if (i >= IntegerCache.low && i <= IntegerCache.high)            return IntegerCache.cache[i + (-IntegerCache.low)];        return new Integer(i);    }
public int intValue() {        return value;    }

  装箱的这个过程是不是有点熟悉?详情可以看一下我之前写的这篇笔记:https://www.cnblogs.com/NYfor2018/p/9482390.html

  而拆箱的过程是简洁不加修饰,我们可以看到它的返回值直接就是int。

  但,是不是那八种基本类型的装箱过程都是相似的呢?不是的,但是它们是跟前面的八种基本数据类型的分类情况是类似的,也就是Integer、Short、Long、Byte的装箱过程,Double和Float的装箱过程、Boolean的装箱过程和Character的装箱过程的分别类似的。

  下面祭上源码:

public static Integer valueOf(int i) {        if (i >= IntegerCache.low && i <= IntegerCache.high)            return IntegerCache.cache[i + (-IntegerCache.low)];        return new Integer(i);}public static Long valueOf(long l) {        final int offset = 128;        if (l >= -128 && l <= 127) { // will cache            return LongCache.cache[(int)l + offset];        }        return new Long(l);}public static Short valueOf(short s) {        final int offset = 128;        int sAsInt = s;        if (sAsInt >= -128 && sAsInt <= 127) { // must cache            return ShortCache.cache[sAsInt + offset];        }        return new Short(s);}public static Byte valueOf(byte b) {        final int offset = 128;        return ByteCache.cache[(int)b + offset];}
public static Double valueOf(double d) {        return new Double(d);} public static Float valueOf(float f) {        return new Float(f);}
public static Boolean valueOf(boolean b) {        return (b ? TRUE : FALSE);}
public static Character valueOf(char c) {        if (c <= 127) { // must cache            return CharacterCache.cache[(int)c];        }        return new Character(c);}

  所以,在做有关于同种数据类型但是数值不一样的面试题的时候,要对症下药。

  有关于基本数据类型的面试题可以看这篇文章,写的很不错:https://blog.csdn.net/u010539271/article/details/69668807

 

-------------------------------------有道面试题-------------------------------------

byte b1=1,b2=2,b3,b6;final byte b4=4,b5=6;b6=b4+b5;b3=(b1+b2); System.out.println(b3+b6); 问题:这代码片段编译之后会出现什么情况?
答案:语句:b3=b1+b2编译出错因为b4和b5已经声明是一个final常量了,所以它在进行运算的时候不会因为要运算而自动转化成int类型(int类型转换成byte需要强制转换,),因此会编译错误。但是因为b4和b5在进行运算的时候不会自动转换成int类型,所以在进行b6=b4+b5语句的时候不会出现错误。

-------------------------------------编码那点事儿-------------------------------------

  值得回去再看看的文章:

  

  

  

  

 

参考:

《Java核心技术I》

https://www.cnblogs.com/dolphin0520/p/3780005.html

https://blog.csdn.net/u010539271/article/details/69668807

 

转载于:https://www.cnblogs.com/NYfor2018/p/9501811.html

你可能感兴趣的文章
/bin,/sbin /usr/sbin,/usr/bin
查看>>
mariadb操作审计
查看>>
Vmawre vsphere 5.5之SSD存储设置
查看>>
Linux CentOS 永久设置别名Alias
查看>>
JavaScript ES6箭头函数指南
查看>>
通过Gradle来取的Jenkins的build
查看>>
Hadoop基础入门学习笔记(基本概念)
查看>>
MongoDB复制集
查看>>
windows系统之WSUS服务器:更改WSUS更新文件的路径
查看>>
highlight testing
查看>>
Python中的module,library,package之间的区别
查看>>
如何处理JSON中的特殊字符
查看>>
客来乐:变革与升级,用技术点燃智慧时代
查看>>
批量创建导入导出域用户
查看>>
Access、Hybrid和Trunk三种模式的理解(转帖)
查看>>
Linux入门(二)
查看>>
创建Writable Materialized View在DB之间增量同步数据
查看>>
运维工程师的职责和前景(一)
查看>>
iptables在网络中的两个经典应用
查看>>
python 异常学习3---python异常except语句用法与引发异常
查看>>