字面常量
在程序中,System.out.println(“Hello World!”);语句中Hello World!就是字面常量。
常量就是运行程序期间固定不变的量
例如:
System.out.println("Hello World!");
System.out.println(true);
System.out.println(false);
System.out.println(1);
System.out.println(1.5);
System.out.println('A');
字面常量也有分类
- 字符串常量:由""括起来的。
- 整型常量:程序中直接写的数字。
- 浮点数常量:程序中的小数。
- 字符常量:单引号引起来的单个字符。
- 布尔常量:true和false。
- 空常量:null。
数据类型
在Java中数据类型分为两类:基本数据类型和引用数据类型。
其中,基本数据类型有四类八种
四类:整型,浮点型,字符型,布尔类型。
八种:
注意:
- 不管是16位系统还是32位系统,上述的数据类型的内存占用不变,例如:int占4个字节。
- 整型和浮点型是带有符号的。
- 默认情况下,整型为int,浮点型为double。
变量
程序中,经常改变的量称为变量,例如身高、体重等。
那么如何定义变量呢?
数据类型 变量名 = 初始值;
例如:
int a = 1;
float b = 1.2;
double c = 3.14;
char d = 'D';
boolean e = true;
整型变量
整型变量
int a = 1;//定义变量时需要给变量初始化
System.out.printlln(a);
//如果在定义时没有给变量初始化,也可以在使用前赋初值
int a;
a = 1;
System.out.println(a);
//int型变量能表示的范围
System.out.println(Integer.MIN_VALUE);//最小值
System.out.println(Integer.MAX_VALUE);//最大值
注意:在给变量赋初始值时,不能超过该数据类型的范围。int的包装类为Integer
短整型变量
short a = 10;
// short型变量能表示的范围:
System.Out.println(Short.MIN_VALUE);//最小值
System.Out.println(Short.MAX_VALUE);//最大值
short的包装类型为Short
长整型变量
long a = 10L;//为了区分int和long类型,建议long类型变量的初始值后加L或者l,一般情况下加L。
//long型变量能表示的范围
System.Out.println(Long.MIN_VALUE);//最小值
System.Out.println(Long.MAX_VALUE);//最大值
long的包装类为Long
字节型变量
byte a = 10;
// byte型变量能表示的范围:
System.Out.println(Byte.MIN_VALUE);//最小值
System.Out.println(Byte.MAX_VALUE);//最大值
字节的包装类型为Byte
浮点型变量
单精度浮点型
float a = 1.0f;//float类型变量的初始值后加F或者f。
float的包装类型为Float
注意:由于表示的数据精度范围较小, 一般在工程上用到浮点数都优先考虑 double, 不太推荐使用 float
双精度浮点型
double a = 3.14;
int a = 1;
int b = 2;
System.out.println(a/b);//输出结果为0
为什么结果为0,而不是0.5呢?
因为在 Java 中, int 除以 int 的值仍然是 int(会直接舍弃小数部分)。如果想得到 0.5, 需要使用 double 类型计算,如下:
double a = 1.0;
double b = 2.0;
System.out.println(a/b);
double a = 1.1;
System.out.println(a * a);//1.2100000000000002
为什么结果不是1.21呢?
double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差,因此浮点数是个近似值,并不是精确值。
double的包装类型为Double。
字符型变量
char c1 = 'A';// 大写字母
char c2 = '1';// 数字字符
注意:Java 中使用 单引号 + 单个字母 的形式表示字符字面值。
char的包装类型为Character。
布尔型变量
boolean a = true;
注意:
- boolean 类型的变量只有两种取值, true 表示真, false 表示假。
- Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用法(不像C语言那样)。
- Java虚拟机规范中,并没有明确规定boolean占几个字节,也没有专门用来处理boolean的字节码指令,在Oracle公司的虚拟机实现中,boolean占1个字节。
- boolean的包装类型为Boolean。
类型转换
在Java中,当参与运算数据类型不一致时,就会进行类型转换。Java中类型转换主要分为两类:自动类型转换(隐式) 和 强制类型转换(显式)。
int a = 10;
long b = 100L;
b = a;//可以编译
a = b;//编译失败
自动类型转换
自动类型转换即在代码编译时,编译器会自动进行处理。
特点:数据范围小的转为数据范围大的时会自动进行。
float a = 3.14;
double b = 100.1;
a = b;//编译错误,数据丢失,不安全
b = a;//小范围转为大范围,自动进行类型转换
强制类型转换
强制类型转换即当进行操作时,代码需要经过一定的格式处理,不能自动完成。
特点:数据范围大的转为数据范围小的。
int a = 10;
long b = 100L;
b = a; // 数据范围由小到大,隐式转换
a = (int)b; // 数据范围由大到小,需要强转,否则编译失败
float f = 3.14F;
double d = 5.12;
d = f;// 数据范围由小到大,隐式转换
f = (float)d; //数据范围由大到小,需要强转,否则编译失败
注意:
- 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型。
- 如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失。
- 将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查。
- 强制类型转换不一定能成功,不相干的类型不能互相转换。
类型提升
类型提升即不同类型的数据之间相互运算时,数据类型小的会被提升到数据类型大的。
- int与long之间:int会被提升为long
int a = 10;
long b = 20.0L;
int c = a + b;//编译错误,int + long,int类型会提升成long类型,赋值给int类型的c会数据丢失
long d = a + b;//30
- byte与byte的运算
byte a = 10;
byte b = 2;
byte c = a + b;//编译错误,byte + byte,两个byte类型都会提升到int类型,赋值给byte类型的会丢失数据
虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这是赋给 c, 就会出现上述错误。
由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short这种低于 4 个字节的类型, 会先提升成 int, 再参与计算。
字符串类型
在Java中使用String类定义字符串类型,例如:
String s1 = "hello";
String s2 = " world";
System.out.println(s1);
System.out.println(s2);
System.out.println(s1+s2); // s1+s2表示:将s1和s2进行拼接
在有些情况下,需要将字符串和整形数字之间进行转换,如:
- int 转成 String
int num = 10;
// 方法1
String str1 = num + "";
// 方法2
String str2 = String.valueOf(num)
- String 转成 int
String str = "100";
int num = Integer.parseInt(str);