java数组元素类型转换_Java基本数据类型与类型转换实例分析

本文实例讲述了Java基本数据类型与类型转换。分享给大家供大家参考,具体如下:

相关内容:

基本数据类型

整型

浮点型

字符型

布尔型

数据类型转换

数组

首发时间:2017-06-22 21:18

修改时间:

2018-03-16 15:40  :修改了一下文字布局和样式,增加了“相关内容”,修改了标题,增加了数组

数据类型:

Java语言是强类型语言,对于每一种数据都定义了明确的具体数据类型,在内存总分配了不同大小的内存空间

1b545f43f8ba285061fe24c033f2156f.png

1e396bb197c68f78b0f33ddb2e151cc1.png 注意:

整数默认类型为:int,所以1 2 3为int型,而非byte

小数默认类型为:double

举个例子--

180da9e377a301a09db078fc543593c6.png

整型:

整型的数据类型包括: byte,short,int,long

他们的大小范围如下:

f0de94b1f7fc716769f6f06e055276b6.png

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

他们的大小范围如下:

71c591c559fddc53559b1ae5cb4059c3.png

float:

给float赋值要加上f,如float=10.2f;否则会失败,因为默认是double,会有精度损失

double:

浮点数默认类型为double

特殊浮点值:

POSITIVE_INFINITY:表示正无穷

NEGATIVE_INFINITY:表示负无穷

NaN:表示非数值

所有的正无穷大数值都是相等的,所有的负无穷大数值都是相等的;而NaN不与任何数值相等,NaN之间也不相等。

只有浮点数除以0才可以得到正无穷或负无穷,整数是除零异常

字符型:

字符类型的数据类型有char

char的字符编码是Unicode编码,所以char支持中文。

8864d8ef76750e0eb4d58fc56bc41b79.png

布尔型:

布尔类型的数据类型为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

97a4a804bff9285357f3f0f0f24f2768.png

2.转换规则:

b7b2a75551d63a4814749efbf0c297ed.png

3.

70061c2f0f25c24af8805a68be07f0a8.png

596b81f62a722c4078341358a72b5d82.png

对于A中,可认为在“普通数字”计算过程中先计算得出结果,再分析是否是byte的范围,如果不是,赋值失败,提示出错,如果是就不提示,赋值成功。

令byte b=256;(已知b=20编译通过)

f396c2d145301cf8a4baed74918ae886.png

注意:+=,++能够自动转换

4.

1.System.out.println(‘a')与System.out.println('a'+1)的区别。

dba48564fee93c70e551f8882b610850.png

8f26cbeeee6a00ce1ac803883cc3ecbd.png

5.

强制转化可以解决精度损失提醒但无法避免精度损失。(数值取值原理同溢出原理)

2ba5e190d7bcba9ea90579eaaf7276fe.png

数组:

数组是相同类型的变量按照顺序组成的一种复合数据类型

数组属于引用型变量。

数组的声明:

数组的元素类型 数组名[];

数组的元素类型[]  数组名;

二维数组的声明:数组的元素类型[][]  数组名;

java不允许在声明数组中的方括号内指定数组元素的个数,错误情况:

72071d7007245dbc74e5bf413e8d92c3.png

数组的元素定义【声明仅仅是声明,并没有创建内存空间,实际的元素还没有存在。】:

数组名=new 数组的元素类型[元素个数]

73295ac70d565199b0f6662872d7213a.png

声明的同时也可以创建数组:

e3eb88a1ff43493e5bc90e5fb41f79ee.png

也可以利用赋值来创建数组:

b6e5a6caf5601dc4affeb9f41bfee27c.png

但int [] arr =new int [3]{1,2,3} 是非法的。

二维数组:

0daa90af5c1a68bebc25a64ce331a54d.png

452aaa8f60747d185eb971b4ff6da6cf.png

数组的初始化:

数组的初始化可以由指定的值初始化,

84ca3d7031c1f22a75f40d212fe9f47a.png

但只指定数组的大小,而不指定值的时候,采用默认初始化:

整数类型的数组默认元素初始值为0

浮点类型的数组的元素初始值为0.0

字符类型的数组的元素初始值是空字符

布尔类型的数组的元素初始值是false

引用类型的数组的元素初始值是null

数组元素的使用:

可以通过索引来取得数组元素:

1080e188a01aa51c2c7bc79e9e14ffeb.png

可以使用.length获取数组的长度:

2504db12e6e7d638f0acf94ee26cd67b.png

补充:

二维数组中的一维数组长度可以不一样:

f4dc432db369c5ccc0a6e21c42b7951e.png

java提供的Arrays类包含了一些static方法能直接操作数组:

比如Arrays.toString(数组):能将数组的元素转成一串字符串

Arrays.fill(数组,value):把数组的所有元素都赋值为value

Arrays.sort(数组):对数组的元素进行排序

....其他

希望本文所述对大家java程序设计有所帮助。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值