1 Java的数据类型
1.1 Java的数据类型概述
几乎所有的编程语言中都会有数据类型,什么是数据类型呢?软件的存在主要是进行数据的处理,现实生活中的数据会有很多,所以编程语言对其进行了分门别类,然后不同的数据类型的数据会给其分配不同大小的空间进行存储。换句话说,Java中的数据类型作用就是指导Java虚拟机在程序运行阶段到底应该给该变量分配多大的内存空间。
1.2 Java中的数据类型包括两种,分别是
● 基本数据类型
● 引用数据类型
1.3 Java中的基本数据类型又包括四类8种
● 整数型(不带小数的数字):byte,short,int,long
● 浮点型(带小数的数字):float,double
● 字符型(文字,单个字符):char
● 布尔型(真和假):boolean
2 字符型
public class CharTest {
public static void main(String[] args) {
char c1 = 'a';
System.out.println(c1);
System.out.println(c1 + 1);
char c2 = '好';
System.out.println(c2);
char c3 = "好"; //双引号为字符串型
System.out.println(c3);
char c4 = 97;
System.out.println(c4);
}
}
编译报错信息:

原因是类型不一致,使用双引号括起来的一定是字符串型,不能赋值给char类型的变量。将其注释后输出:

其中c1+1输出结果为98,因为c1是char类型,1是int类型,char类型和int类型混合运算的时候char类型会自动转换成int类型,然后再做运算,a对应的ASCII码是97,所以最终结果是98。另外还有一行代码char c4 = 97,由于c4是char类型,所以会把97看做ASCII码,所以c4是’a’字符。
2.1 转义字符
\n表示换行符,\’表示普通的单引号字符,\表示一个普通的\字符,\”表示一个普通的双引号字符,\u后面的十六进制是文字的Unicode编码。
3 整数型
public class IntegerTest {
public static void main(String[] args) {
//整数型 占用4个字节
int a = 10;
System.out.println("a=" + a);
//b为long类型,占用8个字节
//long类型需要在字面量后面添加L/l,建议大写L,因为小写l和1不好区分。
long b = 100L;
System.out.println("b=" + b);
//long类型转int类型为小转大,需要强制转换
int c = (int) b;
System.out.println("c=" + c);
//int类型转long类型为大专小,自动转换
long d = a;
System.out.println("d=" + d);
}
}
运行结果:

补充:当一个整数型的字面量没有超出byte,short,char的取值范围,可以将该字面量直接赋值给byte,short,char类型的变量。
4 布尔型
public class BooleanTest {
public static void main(String[] args) {
boolean sex = true;
if(sex){
System.out.println("男");
}else{
System.out.println("女");
}
}
}
运行结果:

public class BooleanTest {
public static void main(String[] args) {
boolean flag = 1;
}
}
报错信息为:

以上两个例子证明:boolean类型的值只有true和false,至少在Java中不含有其他值。
5 浮点型
public class DoubleTest {
public static void main(String[] args) {
float f = 3.0;
}
}
报错信息:

因为3.0默认被当做double类型来处理,占用8个字节,前面的f变量是float类型占用4个字节,大容量无法直接赋值给小容量。
修改方法:
public class DoubleTest {
public static void main(String[] args) {
//float f = 3.0;
//第一种方案
float f = 3.0F;
System.out.println("f = " + f);
//第二种方案
float f1 = (float)3.0;
System.out.println("f1 = " + f1);
}
}
运行结果:

第一种方案在3.0后面添加了F,3.0F被当做float类型来处理。第二种方案是进行了强制类型转换,第二种方案可能会存在精度损失。
6 基本数据类型转换规则
-
如果整数型字面量没有超出byte,short,char的取值范围,可以直接将其赋值给byte,short,char类型的变量;
-
小容量向大容量转换称为自动转换,容量从小到大的排序为:byte < short(char) < int < long < float < double
注:short和char都占用两个字节,但是char可以表示更大的正整数;
-
大容量转换成小容量,称为强制类型转换,编写时必须添加“强制类型转换符”,但运行时可能出现精度损失;