数据类型与运算符
1、变量和类型
1.1、整形变量
基本语法格式:
int 变量名 = 初始值;
代码示例:
int num = 10 //定义一个整型变量
System.out.println(num);
注意:
1)java中,一个int变量占4个字节,和操作系统没有直接关系。
(8个bit为一个字节Byte,1KB = 1024 Byte)
2)4 个字节表示的数据范围是 -2^31 -> 2^31-1,也就大概是 -21亿 到 +21亿
1.2长整型变量
基本语法格式:
long 变量名 = 初始值;
代码示例:
long num = 10L; //定义一个长整型变量,初始值也可以写10l(小写L不是数字1)
System.out.println(num);
注意:
1)使用 10 初始化也可以,10 的类型是 int,10L 的类型是 long,使用 10L或者 10l更好一些.
2)Java 中 long 类型占 8 个字节,表示的数据范围 -2^63 -> 2^63-1
System.out.println(Long.MAX_VALUE);
System.out.println(Long.MIN_VALUE);
// 运行结果
9223372036854775807
-9223372036854775808
1.3、双精度浮点型变量
基本语法格式:
double 变量名 = 初始值;
代码示例:
double num = 1.0;
System.out.println(num);
int除以int的值仍然是int
int a = 1;
int b = 2;
System.out.println(a / b);
// 执行结果
0
double a = 1.0;
double b = 2.0;
System.out.println(a / b);
// 执行结果
0.5
1.4、单精度浮点型变量
基本语法格式:
float 变量名 = 初始值;
代码示例:
float num = 1.0f;//F也可
System.out.println(num);
float 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据精度范围较小, 一般在工程上用到浮点数都
优先考虑 double, 不太推荐使用 float
1.5、字符类型变量
基本语法格式:
char 变量名 = 初始值;
代码示例:
char ch = 'A';
1.6、字节类型变量
基本语法格式:
byte 变量名 = 初始值;
代码示例:
byte value = 0 ;
System.out.println(value);
1)字节类型表示的也是整数. 只占一个字节, 表示范围较小 ( -128 -> +127 )
2)字节类型和字符类型互不相干
1.7、短整型变量
基本语法格式:
short 变量名 = 初始值;
代码示例:
short value = 0 ;
System.out.println(value);
short 占用 2 个字节, 表示的数据范围是 -32768 -> +32767,这个表示范围比较小, 一般不推荐使用
1.8、布尔类型变量
太累了,,,随便写点总结吧。。。
1.9、转义字符
转义字符 | 解释 |
---|---|
是 | 是 |
2、小结
1、Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true,0 表示 false 这样的用法
2、String 不是基本类型,而是引用类型
3、不同数字类型的变量之间赋值,表示范围更小的类型能隐式转换成范围较大的类型,反之则不行(int a = 10; long b = 20;
a = b; // 编译出错, 提示可能会损失精度. b = a;//编译通过)
4、使用 (类型) 的方式可以将 double 类型强制转成 int。但是强制类型转换可能会导致精度丢失,如赋值之后, 10.5 就变成 10 了, 小数点后面的部分被忽略。强制类型转换不是一定能成功,互不相干的类型之间无法强转。
5、对于 short, byte 这种比 4 个字节小的类型,会先提升成 4 个字节的 int ,再运算。
6、如果不取自增运算的表达式的返回值,则前置自增和后置自增没有区别;如果取表达式的返回值,则前置自增的返回值是自增之后的值,后置自增的返回值是自增之前的值。
7、短路求值: 对于 &&,如果左侧表达式值为 false, 则表达式的整体的值一定是 false, 无需计算右侧表达式;对于 ||,如果左侧表达式值为 true, 则表达式的整体的值一定是 true, 无需计算右侧表达式(& 和 | 如果操作数为 boolean 的时候, 也表示逻辑运算。但是和 && 以及 || 相比,它们不支持短路求值)
8、移位运算:左移 1 位 <<1 , 相当于原数字 * 2,左移 N 位, 相当于原数字 * 2 的N次方;
右移 1 位 >>1 , 相当于原数字 / 2,右移 N 位,相当于原数字 / 2 的N次方。
9、三目运算符:表达式1 ? 表达式2:表达式3(当表达式1 的值为 true 时,整个表达式的值为表达式2的值;当表达式1的值为 false 时,整个表达式的值为 表达式3的值)