java new 数据类型_Java之基本数据类型

本文章分为四个部分:

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->long

char->int->long

float->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反编译一下就知道这两条语句对应的是不是装箱和拆箱了。

0618f4f6c7b9a6c8dd10227e62f03e37.png

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

public static Integer valueOf(inti) {if (i >= IntegerCache.low && i <=IntegerCache.high)return IntegerCache.cache[i + (-IntegerCache.low)];return newInteger(i);

}

public intintValue() {returnvalue;

}

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

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

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

下面祭上源码:

public static Integer valueOf(inti) {if (i >= IntegerCache.low && i <=IntegerCache.high)return IntegerCache.cache[i + (-IntegerCache.low)];return newInteger(i);

}public static Long valueOf(longl) {final int offset = 128;if (l >= -128 && l <= 127) { //will cache

return LongCache.cache[(int)l +offset];

}return newLong(l);

}public static Short valueOf(shorts) {final int offset = 128;int sAsInt =s;if (sAsInt >= -128 && sAsInt <= 127) { //must cache

return ShortCache.cache[sAsInt +offset];

}return newShort(s);

}public static Byte valueOf(byteb) {final int offset = 128;return ByteCache.cache[(int)b +offset];

}

public static Double valueOf(doubled) {return newDouble(d);

}public static Float valueOf(floatf) {return newFloat(f);

}

public static Boolean valueOf(booleanb) {return (b ?TRUE : FALSE);

}

public static Character valueOf(charc) {if (c <= 127) { //must cache

return CharacterCache.cache[(int)c];

}return newCharacter(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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值