- ⭐前言⭐
- 变量和类型
- 整型
- 长整型变量
- 双精度浮点型
- 单精度浮点型
- 字符类型
- 字节类型变量
- 短整型变量
- 布尔类型变量
- 字符串类型变量
- 转义字符
- 常量
- 字面值常量
- final修饰常量
- 类型转换
- 运算符
- 基本四则运算符
- 关系运算符
- 逻辑运算符
- 位运算符
变量和类型 整型欢迎关注点赞收藏⭐️留言
GithubJava仓库,欢迎点击访问
博主的笔记链接
基本语法格式
int name = data;
实例
int num = 1;//定义一个整型变量,数值为1 System.out.println(num);
System.out.println(Integer.MAX_VALUE);//整型数据最大值 System.out.println(Integer.MIN_VALUE);//整型数据最小值长整型变量
基本语法格式
long name = data;
实例
long num=1L;//定义一个长整型变量,初始值为 1L long num2=1l;//后面的字母也可以用小写,但是小写特别像1,改用大些用以区分双精度浮点型
基本语法格式
double name = data;
实例
double num = 1.0;单精度浮点型
基本语法格式
float name = data;
实例
float num = 1.0f; float num2=2.0F;字符类型
基本语法格式
char name = data;
实例
char ch = 'A';
需要注意的是,Java中字符类型占两个字节,与C语言中所占一个字节有区别
字节类型变量基本语法格式
byte name = data;
实例
byte value=0;
在C语言中没有这个类型,这个类型占一个字节。
短整型变量基本语法格式
short name = data;布尔类型变量
基本语法格式
boolean name = data;
实例
boolean value = true; boolean value = false;
注意
- boolean 类型的变量只有两种取值, true 表示真, false 表示假.
- Java 的 boolean 类型和 int 不能相互转换, 不存在 1 表示 true, 0 表示 false 这样的用法.
- boolean 类型有些 JVM 的实现是占 1 个字节, 有些是占 1 个比特位, 这个没有明确规定.
在C语言中没有字符串类型,但是在Java中有字符串类型
String name = "data";
实例
String name = "java";
区分
char ch='A'; String str="A";
注意
- Java 使用 双引号 + 若干字符 的方式表示字符串字面值。
- 和上面的类型不同, String 不是基本类型, 而是引用类型。
- 字符串中的一些特定的不太方便直接表示的字符需要进行转义。
字符串的拼接
String a = "hello"; String b = "world"; String c = a + b; System.out.println(c);
String str = "result = "; int a = 10; int b = 20; String result = str + a + b; System.out.println(result);转义字符
| 字符 | 意义 |
|---|---|
| n | 换行 |
| t | 水平制表符 |
| ’ | 单引号 |
| " | 双引号 |
| \ | 反斜杠 |
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 字面值常量, 双引号中可以有多个字符.final修饰常量
final int a = 10; a = 20; // 编译出错,提示无法为最终变量a分配值
类型转换有点类似C语言中的const修饰变量
int和long/double相互转换
int a = 10; long b =20; a = b;// 编译出错, 提示可能会损失精度. b = a;// 编译通过 int a = 10; double b = 1.0; a = b; // 编译出错, 提示可能会损失精度. b = a; // 编译通过.
long 表示的范围更大, 可以将 int 赋值给 long, 但是不能将 long 赋值给 int.
double 表示的范围更大, 可以将 int 赋值给 double, 但是不能将 double 赋值给 int.
结论: 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型, 反之则不行.
强制类型转换
int a = 0; double b = 10.5; a = (int)b; int a = 10; boolean b = false; b = (boolean)a; // 编译出错, 提示不兼容的类型.
结论:使用 (类型) 的方式可以将 double 类型强制转成 int. 但是
- 强制类型转换可能会导致精度丢失. 如刚才的例子中, 赋值之后, 10.5 就变成 10 了, 小数点后面的部分被忽略.
- 强制类型转换不是一定能成功, 互不相干的类型之间无法强转.
总结:
- 不同数字类型的变量之间赋值, 表示范围更小的类型能隐式转换成范围较大的类型.
- 如果需要把范围大的类型赋值给范围小的, 需要强制类型转换, 但是可能精度丢失.
- 将一个字面值常量进行赋值的时候, Java 会自动针对数字范围进行检查.
数值提升
int和long混合运算
int a=10; long b=20; int c=a+b; long d=a+b;
byte和byte的运算
byte a = 10; byte b = 20; byte c = a + b; System.out.println(c);运算符 基本四则运算符
整型相除还是整型,如果需要得到小数就需要double型变量进行运算
关系运算符== != < > <= >=
int a = 10; int b = 20; System.out.println(a == b); System.out.println(a != b); System.out.println(a < b); System.out.println(a > b); System.out.println(a <= b); System.out.println(a >= b);逻辑运算符
&& || !
逻辑于------->两者都为真时为真
逻辑或------->一个为真时即为真
取反---------->真变假,假变真
对于a&&b如果a为假则结束,不在判断b是真是假
对于a||b如果a为真则结束,不在判断b是真是假
位运算符& | ~ ^
注意:位操作符是对二进制位进行运算
a&b--------->二进制位都是1则为1,否则取0
a|b--------->二进制位只要有一个为1就是1
~a---------->取反,二进制位是1则变0,0则变为1
a^b--------->二进制位相同为0,相异为1
a=11001B=25
b=10110B=22
a&b=10000B=16
a||b=11111=31
a的补码0…11001取反1…00110—>原码1…11010= -26
a^b=01111=15
如有不足之处,欢迎批评指正!



