Java基本数据类型与类型转换的方法
这篇文章主要讲解了Java基本数据类型与类型转换的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
成都创新互联专业提供成都主机托管四川主机托管成都服务器托管四川服务器托管,支持按月付款!我们的承诺:贵族品质、平民价格,机房位于中国电信/网通/移动机房,移动服务器托管服务有保障!
相关内容:
- 基本数据类型
- 整型
- 浮点型
- 字符型
- 布尔型
- 数据类型转换
- 数组
首发时间:2017-06-22 21:18
修改时间:
- 2018-03-16 15:40 :修改了一下文字布局和样式,增加了“相关内容”,修改了标题,增加了数组
数据类型:
Java语言是强类型语言,对于每一种数据都定义了明确的具体数据类型,在内存总分配了不同大小的内存空间
注意:
- 整数默认类型为:int,所以 1 2 3为int型,而非byte
- 小数默认类型为:double
- 举个例子--
整型:
整型的数据类型包括: byte,short,int,long
他们的大小范围如下:
byte
- byte共占8个bit,表示256个数(28)。
- 最大值为01111111,转成十进制为127
- 最小值为10000000,1是符号位,表示负数,转成十进制为128。所以最小值为-128
- 对byte类型进行数学运算时,会自动提升为int类型,如果表达式中有double或者float等类型,也是自动提升。
- byte s1 = 100;
- byte s2 = 'a';
- byte sum = s1 + s2;//错误--》因为变成int了,不能直接将一个int赋值给一个byte
short
- short类型参与运算的时候,一样被提升为int或者更高的类型。
int
- 整数默认类型为:int
long
- 在表示long类型的值时,需要在数值末尾加上l或L,建议是L,因为l难认
- long比int大,有long则计算提升为long
浮点型:
浮点型的数据类型包括:float,double
他们的大小范围如下:
float:
- 给float赋值要加上f,如float=10.2f;否则会失败,因为默认是double,会有精度损失
double:
浮点数默认类型为double
特殊浮点值:
POSITIVE_INFINITY:表示正无穷
NEGATIVE_INFINITY:表示负无穷
NaN:表示非数值
所有的正无穷大数值都是相等的,所有的负无穷大数值都是相等的;而NaN不与任何数值相等,NaN之间也不相等。
只有浮点数除以0才可以得到正无穷或负无穷,整数是除零异常
字符型:
字符类型的数据类型有char
- char的字符编码是Unicode编码,所以char支持中文。
布尔型:
布尔类型的数据类型为boolean
boolean只有两个值:true,false
注意:
不使用--不出现不初始化,使用--必须初始化,true/false
boolean的值只占一个字节。
boolean只有true和false
赋值:boolean b =true
类型转换:
运算中,不同类型的数据先转化为同一类型,然后进行运算
有自动类型转换和强制类型转换:
自动类型转换如byte+long的结果自动是long
强制类型转换是把其他类型的结果转换成目标类型如byte b=(byte)600;
转换规则:
1.即使是同类型计算,在运算中byte ,short,char也要先转化为int型
byte b1=3,b2=4,b;
b=b1+b2;
b=3+4;
哪句是编译失败的呢?为什么呢?
answer:b=b1+b2 ,因为两个byte变量的运算也会转成int的运算,所以b1+b2的结果是一个int
2.转换规则:
3.
对于A中,可认为在“普通数字”计算过程中先计算得出结果,再分析是否是byte的范围,如果不是,赋值失败,提示出错,如果是就不提示,赋值成功。
令byte b=256;(已知b=20编译通过)
注意:+=,++能够自动转换
4.
1.System.out.println(‘a')与System.out.println('a'+1)的区别。
5.
强制转化可以解决精度损失提醒但无法避免精度损失。(数值取值原理同溢出原理)
数组:
- 数组是相同类型的变量按照顺序组成的一种复合数据类型
- 数组属于引用型变量。
数组的声明:
- 数组的元素类型 数组名[];
- 数组的元素类型[] 数组名;
- 二维数组的声明:数组的元素类型[][] 数组名;
- java不允许在声明数组中的方括号内指定数组元素的个数,错误情况:
数组的元素定义【声明仅仅是声明,并没有创建内存空间,实际的元素还没有存在。】:
- 数组名=new 数组的元素类型[元素个数]
- 声明的同时也可以创建数组:
- 也可以利用赋值来创建数组:
- 但int [] arr =new int [3]{1,2,3} 是非法的。
- 二维数组:,
数组的初始化:
- 数组的初始化可以由指定的值初始化,
- 但只指定数组的大小,而不指定值的时候,采用默认初始化:
- 整数类型的数组默认元素初始值为0
- 浮点类型的数组的元素初始值为0.0
- 字符类型的数组的元素初始值是空字符
- 布尔类型的数组的元素初始值是false
- 引用类型的数组的元素初始值是null
数组元素的使用:
可以通过索引来取得数组元素:
可以使用.length获取数组的长度:
补充:
- 二维数组中的一维数组长度可以不一样:
- java提供的Arrays类包含了一些static方法能直接操作数组:
- 比如Arrays.toString(数组):能将数组的元素转成一串字符串
- Arrays.fill(数组,value):把数组的所有元素都赋值为value
- Arrays.sort(数组):对数组的元素进行排序
看完上述内容,是不是对Java基本数据类型与类型转换的方法有进一步的了解,如果还想学习更多内容,欢迎关注创新互联行业资讯频道。
分享标题:Java基本数据类型与类型转换的方法
网址分享:http://pwwzsj.com/article/jeppjd.html