java数据类型int_java数据类型

java的数据类型分为两大类:基本数据类型和引用数据类型

这里我们先说一下基本数据类型,基本数据类型分为四种:整型、浮点型、字符型、布尔类型

(1)整型根据取值范围从小到大依次为:byte、short、int、long

1.一般情况下,整型类型的数值默认为int类型;通常情况下,取值范围大的类型转换为小的类型时处出现问题,程序如下所示:

public static void main(String[] args){

int x = 127;

byte y = x;

System.out.println(y);

}

这个时候编译并运行程序会报错,因为从取值范围大的类型转换成取值范围小的类型会有损失,即使你这个值在取值范围小的类型中。

b6a37bbdca54a13dacb0a98861d1552c.png

要想从取值范围大的类型转换成取值范围小的类型不报错,需要通过强制转换,程序如下所示:

public static void main(String[] args){

int x = 127;

byte y = (byte)x;

System.out.println(y);

}

程序编译并运行成功

9c4086702d830dc17c7b585be189a23a.png

2.现在是因为值小,所以没有造成数据损失,下面列举一个会出现数据损失的问题:

public static void main(String[] args){

int x = 128;

byte y = (byte)x;

System.out.println(y);

}

这个时候输出结果就出现问题了,因为需要强制转换的值已经超过了byte类型的最大值,需要注意的一点是,当一个值的大小超过了数据类型的范围时,

超出多少,就是在最小值的基础上加上超出的这个值再减去1,最后得出的值就是结果

0503520426ae66787648ba8a7c07428c.png

3.不同类型的值在进行运算时,所得结果会自动转换为取值范围大的类型,程序如下:

public static void main(String[] args){

int x = 1;

byte y = 127;(byte类型的最大值)

System.out.println(x+y);

}

程序编译运行后的结果如下,输出128的原因是因为int类型与byte类型进行运算时,结果自动转换为了int类型,所以输出结果为128

456fd96e2d6655aec33dab92cd684304.png

(2)浮点型:double和float

double的取值范围比float类型的取值范围大很多,所以当写一个小数时,默认为double类型

public static void main(String[] args){

float x = 1.0;

System.out.println(x);

}

将该程序编译后会报错,因为带小数的值默认为double类型,又因为double类型的范围比float大,所以在编译过程中会报错

a9bf4ccf73dcc819c86cd0d91da83547.png

但是你要是这样写 float x = 1.0f 就不会报错了,这样写表明该值为float类型的

(3)字符型:char

字符类型的值用" ' " 表示,即char x = 'A' ,要注意的是字符类型的值会与数字相对应,即每个字符会对应一个数字,程序如下:

public static void main(String[] args){

char x = 'A';

char y = 'a';

System.out.println("A:"+(int)x);

System.out.println("a:"+(int)y);

}

程序编译并运行后,输出结果如下:

8c5cd8f07ab95b22cef5acb6114374f6.png

注意:'0'与0 的值不一样,感兴趣的可以试一试

(4)布尔类型:有两个值 true 和 false

一般该类型用于逻辑判断,程序如下:

public static void main(String[] args){

boolean x = true;

if(x){

System.out.println("true");

}

}

程序编译并运行后输出结果如下:

ea6b08217d97185defcf8bcfbb385690.png


版权声明:本文为weixin_35460054原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。