变量指的是程序运行时可变的量,相当于开辟一块内存空间来保存一些数据类型则是对变量的种类进行了划分, 不同的类型的变量具有不同的特性。
基本语法格式:
int 变量名 = 初始值;
代码示例:
int num = 10; //定义一个整型变量
System.out.println(num);
在java中,一个int变量占4个字节,这和C/C++不同,和操作系统没有直接关系。
字节是计算机中表示空间大小的基本单位.
计算机使用二进制表示数据. 我们认为 8 个二进制位(bit) 为一个字节(Byte),4个字节表示的数据范围是 -2^31 到 2^31-1
注意:
基本语法格式:
long 变量名 = 初始值;
代码示例:
long num = 10L; //定义一个长整型变量,初始值写作10l也可以(小写L)
System.out.println(num);
注意:
基本语法格式:
double 变量名 = 初始值;
代码示例:
double num = 1.1;
System.out.println(num * num)
// 执行结果
1.2100000000000002
注意:
Java 中的 double 虽然也是 8 个字节, 但是浮点数的内存布局和整数差别很大, 不能单纯的用 2 ^ n 的形式表示数据范围。
Java 的 double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差。
基本格式:
float 变量名 = 初始值;
代码示例:
float num = 1.0; //这样写是不对的,1.0默认为double类型
float num = 1.0f; // 写作 1.0F 也可以
System.out.println(num);
注意:
float 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都优先考虑 double, 不太推荐float。
基本格式:
char 变量名 = 初始值;
代码示例:
char ch = 'A';
注意:
Test.java:3: 错误: 未结束的字符文字
char ch = '鍛?';
^
此时我们在执行 javac 时加上 -encoding UTF-8 选项即可
javac -encoding UTF-8 文件名.java
基本语法格式:
byte 变量名 = 初始值;
代码示例:
byte value = 0;
System.out.println(value);
注意:
基本语法格式:
short 变量名 = 初始值;
代码示例:
short value = 0;
System.out.println(value);
注意:
基本语法格式:
boolean 变量名 = 初始值;
代码示例:
boolean value = true;
System.out.println(value);
注意:
基本语法格式:
String 变量名 = "初始值";
代码示例:
String name = "zhangsan";
System.out.println(name);
注意:
// 创建一个字符串 My name is "张三"
String name = "My name is \"张三\""; // \" 转义为双引号
转义字符有很多,详情见 常见转义字符
字符串的 **+**操作,表示字符串拼接:
//字符串拼接
String a = "hello";
String b = "world";
String c = a + b;
System.out.println(c);
// 执行结果
helloworld
//还可以用字符串和整数进行拼接:
String str = "result = ";
int a = 10;
int b = 20;
String result = str + a + b;
System.out.println(result);
// 执行结果
result = 1020
//以上代码说明, 当一个 + 表达式中存在字符串的时候, 都是执行字符串拼接行为.因此我们可以很方便的使用System.out.println 同时打印多个字符串或数字
但是注意:
int a = 10;
int b = 20;
System.out.println("a+b);
//运行结果是30 而不是1020
System.out.println("a+“ ”+b);
//这样打印出来的才是a和b的值
一般就是该变量能生效的范围,一般是变量定义所在的代码块(大括号)
硬性指标:
软性指标:
int maxValue = 100;
String studentName = "张三";
每种类型的变量也对应着一种相同类型的常量.常量指的是运行时类型不能发生改变.
常量主要有一下两种体现形式:
1.字面值常量
10 // int 字面值常量(十进制)
010 // int 字面值常量(八进制) 由数字 0 开头. 010 也就是十进制的 8
0x10 // int 字面值常量(十六进制) 由数字 0x 开头. 0x10 也就是十进制的 16
10L // long 字面值常量. 也可以写作 10l (小写的L)
1.0 // double 字面值常量. 也可以写作 1.0d 或者 1.0D
1.5e2 // double 字面值常量. 科学计数法表示. 相当于 1.5 * 10^2
1.0f // float 字面值常量, 也可以写作 1.0F
true // boolen 字面值常量, 同样的还有 false
'a' // char 字面值常量, 单引号中只能有一个字符
"abc" // String 字面值常量, 双引号中可以有多个字符.
2.final 关键字修饰的常量
final int a = 10;
a = 20; // 编译出错. 提示 无法为最终变量a赋值
结论:常量不能在程序运行过程中发生修改。
int 和 long/double 相互赋值:
int a=10;
long b=20;
a = b; //高类型向低类型转换会编译出错,提示可能会损失精度
b = a; //低转高 没有问题,编译通过
int a = 10;
double b = 1.0;
a = b; // 高类型向低类型转换会编译出错,提示可能会损失精度
b = a; //编译通过
int 和 boolean 相互赋值:
int a = 10;
boolean b = true;
b = a; // 编译出错, 提示不兼容的类型
a = b; // 编译出错, 提示不兼容的类型
int 字面值常量给byte赋值
byte a = 100; // 编译通过
byte b = 256; // 超出该类型数据范围会编译报错, 提示从int转换到byte可能会有损失
结论:
int a = 0;
double b = 10.5;
a = (int)b;
int a = 10;
boolean b = false;
b = (boolean)a; //编译出错,提示不兼容的类型
结论:
使用 变量a = (类型)变量b 的方式可以将 double 类型强制转成 int. 但是
int 和long 混合运算:
int a = 10;
long b = 20;
int c = a + b; // 编译出错, 提示将 long 转成 int 会丢失精度
int c = (long)a + b;//使用强制类型转换,编译通过
long d = a + b; // 编译通过.
结论:
当 int 和 long 混合运算的时候, int 会提升成 long, 得到的结果仍然是 long 类型, 需要使用 long 类型的变量来接收结果. 如果非要用 int 来接收结果, 就需要使用强制类型转换.
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;
^
//正确写法:
byte c = (byte)(a + b);
结论:
byte 和 byte 都是相同类型, 但是出现编译报错. 原因是, 虽然 a 和 b 都是 byte, 但是计算 a + b 会先将 a 和 b 都提升成 int, 再进行计算, 得到的结果也是 int, 这时赋给 c, 就会出现上述错误.由于计算机的 CPU 通常是按照 4 个字节为单位从内存中读写数据. 为了硬件上实现方便, 诸如 byte 和 short 这种低于4 个字节的类型, 会先提升成 int, 再参与计算。
int num = 10;
// 方法1
String str1 = num + "";
// 方法2
String str2 = String.valueof(num);
String str = "100";
int num = Integer.parseInt(str);