一、基本概念
(一)、变量概念
在程序中,除了有始终不变的常量外,有些内容困难会经常改变,比如:人的年龄,身高、成绩分数、数学函数的计算结果等,对于这些经常改变的内容,在Java程序中,称为变量。而数据类型就是用来定义不同种类变量的。此外,所有变量都有一个作用域,它定义了变量的可视度和生命周期。
(二)、语法格式
定义变量的语法格式为:
1、数据类型 变量名=初始值;
2、举例
public class DataType {
public static void main(String[] args) {
int a=10;//定义整形变量a,a是变量名也称为标识符,该变量中放置的值为10
double d=3.14;
char c='A';
boolean b=true;
System.out.println(a);
System.out.println(d);
System.out.println(c);
System.out.println(b);
a=100;//a是变量,a中的值是可以修改的,注意:=在Java中表示赋值,即将100交给a,a中保存的值就是100
System.out.println(a);
//注意:在一行可以定义多个相同类型的变量
int a1=10,a2=20,a3=30;
System.out.println(a1);
System.out.println(a2);
System.out.println(a3);
}
}
3、易错问题
(三)、整型变量
1、代码段
public class DataType {
public static void main(String[] args) {
//方式一:在定义时给出初始值
int a=10;
System.out.println(a);
//方式二:在定义的时候没有给初始值,但使用前必须设置初始值
int b;
b=10;
System.out.println(b);
//使用方法二定义后,在使用前没有赋值,则编译期间会报错
int c;
System.out.println(c);
c=100;
}
2、编译结果
(三)、浮点型变量
1、双精度浮点型
double d = 3.14;
System.Out.println(d);
2、神奇的代码一:
int a = 1;
int b = 2;
System.out.println(a / b); // 输出 0.5 吗?
在Java中,int除以int的值仍然是int(会直接舍弃小数部分)。如果想得到0.5,需要用double类型计算。
double a = 1.0;
double b = 2.0;
System.out.println(a / b); // 输出0.5
3、神奇的代码二:
double num = 1.1;
System.out.println(num * num); // 输出1.21吗?
// 执行结果1.2100000000000002
4、注意事项:
(1)double在任何系统下都占8个字节
(2)浮点数与整数在内存中的存储方式不同,不能单纯使用的2的n次方形式来计算
(3)double类型的内存布局遵守IEEE 754标准(和c语言一样),尝试使用有限的内存空间表示可能无限的小数,势必会存在一定的精度误差,因此浮点数是个近似值,并不是精确值。
5、单精度浮点型
float num = 1.0f; // 写作 1.0F 也可以
System.out.println(num);
float 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都优先考虑 double, 不太推荐使用 float.
(四)、字符型变量
public class DataType {
public static void main(String[] args) {
char c1='A';
char c2='1';
System.out.println(c1);
System.out.println(c2);
//注意:java中的字符可以存放整形
char c3='美';
System.out.println(c3);
}
注意事项:
1. Java 中使用 单引号 + 单个字母 的形式表示字符字面值.
2. 计算机中的字符本质上是一个整数. 在 C 语言中使用 ASCII 表示字符, 而 Java 中使用 Unicode 表示字符. 因此一个字符占用两个字节, 表示的字符种类更多, 包括中文.
3、执行 javac 的时候可能出现以下错误:
Test.java:3: 错误: 未结束的字符文字
char ch = '鍛?';
^
此时我们在执行 javac 时加上 -encoding UTF-8 选项即可
javac -encoding UTF-8 Test.java
二、类型转换
(一)、变量类型的转换
在编写程序时,经常需要将一种类型的值赋给另一种类型的变量,如果两种类型兼容,java将自动完成转换,例如将一个int值赋予一个long变量,然而并非所有类型都是兼容的,因此并非所有转换都是默许的,例如从double到byte之间的转换,在这种情况下,就必须使用一种强制转换来完成两种不兼容类型间的直接转换。
1、系统自动转换
系统自动转换时可以把所占内存空间字节少的类型自动转换成所占内存空间字节较多的类型,精度不损失的转换一般规律为(byte,short,char)→int→long,float→double,int→double
当一种类型的数据赋值给另外一种类型的变量时,如果两种类型兼容,如long类型(64位)兼容int类型(32位),double类型兼容float类型,将进行类型自动转换。
char类型数据参与运算时,会自动转换成对应的Unicode整数值。
2、强制类型转换
在java不能进行自动转换的情况下,需要使用显示的强制类型转换,例如当把一个int只赋予一个byte变量时,由于byte在内存中位宽小于int,精度可能有损失,因此需要使用显示的强制类型转换。
(二)、自动类型转换(隐式)
1、自动类型转换即:
代码不需要经过任何处理,在代码编译时,编译器会自动进行处理。
2、特点:
数据范围小的转为数据范围大的时会自动进行。
3、代码段

(三)、强制类型转换(显式)
1、 强制类型转换:
当进行操作时,代码需要经过一定的格式处理,不能自动完成。
2、特点:
数据范围大的到数据范围小的。
3、代码段
4、 注意事项:
(1). 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型
(2). 如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失
(3). 将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查
(4). 强制类型转换不一定能成功,不相干的类型不能互相转换
(四)、类型提升
不同类型的数据之间相互运算时,数据类型小的会被提升到数据类型大的。
1. int与long之间:int会被提升为long
int a = 10;
long b = 20;
int c = a + b; // 编译出错: a + b--->int + long---> long + long 赋值给int时会丢失数据long d = a + b; // 编译成功:a + b---->int + long--->long + long 赋值给long
2. byte与byte的运算
byte a = 10;
byte b = 20;
byte c = a + b;
System.out.println(c);
// 编译报错
Test.java:5: 错误: 不兼容的类型: 从int转换到byte可能会有损失
byte c = a + b;
^
(1)、结论:
byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误.由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short这种低于 4 个字节的类型, 会先提升成 int, 再参与计算.
(2)、正确的写法
byte a = 10;
byte b = 20;
byte c = (byte)(a + b);
System.out.println(c);
3、类型提升小结:
(1). 不同类型的数据混合运算, 范围小的会提升成范围大的.
(2). 对于 short, byte 这种比 4 个字节小的类型, 会先提升成 4 个字节的 int , 再运算.
(五)、字符串类型
1、代码段
public static void main(String[] args) {
String s1 = "hello";
String s2 = " world";
System.out.println(s1);
System.out.println(s2);
System.out.println(s1+s2); // s1+s2表示:将s1和s2进行拼接
}
在有些情况下,需要将字符串和整形数字之间进行转换:
2、 int 转成 String
int num = 10;
// 方法1
String str1 = num + "";
// 方法2
String str2 = String.valueOf(num);
3. String 转成 int
String str = "100";
int num = Integer.parseInt(str);