一、基本数据类型(4类 8种)
- 整数型:byte、short、int 、long
- 浮点型:foat、double
- 字符型:char
- 布尔型:boolean、
注:1.Java中的默认类型:整数类型是 int 、浮点类型是 double ;
2.科学计数法省空间,数据范围和字节占用不一定相关;
3.Java种char类型是可以表示中文的因为它的容量足够大
4.字符串不是基本数据类型,而是引用类型
5.浮点型可能只是一个近似值,并非一个精确的值
6.浮点数当中默认类型是double,如果一定要使用float类型,需要加上一个后缀f/F(大写小写都是可以的),整数默认int,如果要用long就得在后面加上大写字母L(eg: 100L)
二、引用数据类型:
字符串、数组、类、接口、lambda
数据类型的强制转换:
1 /* 2 当数据类型不一样时,将会发生数据类型转换。 3 4 自动类型转换(隐式) 5 1. 特点:代码不需要进行特殊处理,自动完成。 6 2. 规则:数据范围从小到大。 7 8 强制类型转换(显式) 9 */ 10 public class Demo01DataType { 11 public static void main(String[] args) { 12 System.out.println(1024); // 这就是一个整数,默认就是int类型 13 System.out.println(3.14); // 这就是一个浮点数,默认就是double类型 14 15 // 左边是long类型,右边是默认的int类型,左右不一样 16 // 一个等号代表赋值,将右侧的int常量,交给左侧的long变量进行存储 17 // int --> long,符合了数据范围从小到大的要求 18 // 这一行代码发生了自动类型转换。 19 long num1 = 100; 20 System.out.println(num1); // 100 21 22 // 左边是double类型,右边是float类型,左右不一样 23 // float --> double,符合从小到大的规则 24 // 也发生了自动类型转换 25 double num2 = 2.5F; 26 System.out.println(num2); // 2.5 27 28 // 左边是float类型,右边是long类型,左右不一样 29 // long --> float,范围是float更大一些,符合从小到大的规则 30 // 也发生了自动类型转换 31 float num3 = 30L; 32 System.out.println(num3); // 30.0 33 } 34 }
强制转换
1 /* 2 强制类型转换 3 1. 特点:代码需要进行特殊的格式处理,不能自动完成。 4 2. 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据; 5 6 注意事项: 7 1. 强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出。 8 2. byte/short/char这三种类型都可以发生数学运算,例如加法“+”. 9 3. byte/short/char这三种类型在运算的时候,都会被首先提升成为int类型,然后再计算。 10 4. boolean类型不能发生数据类型转换 11 */ 12 public class Demo02DataType { 13 public static void main(String[] args) { 14 // 左边是int类型,右边是long类型,不一样 15 // long --> int,不是从小到大 16 // 不能发生自动类型转换! 17 // 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据; 18 int num = (int) 100L; 19 System.out.println(num); 20 21 // long强制转换成为int类型 22 int num2 = (int) 6000000000L; 23 System.out.println(num2); // 1705032704 24 25 // double --> int,强制类型转换 26 int num3 = (int) 3.99; 27 System.out.println(num3); // 3,这并不是四舍五入,所有的小数位都会被舍弃掉 28 29 char zifu1 = 'A'; // 这是一个字符型变量,里面是大写字母A 30 System.out.println(zifu1 + 1); // 66,也就是大写字母A被当做65进行处理 31 // 计算机的底层会用一个数字(二进制)来代表字符A,就是65 32 // 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字 33 34 byte num4 = 40; // 注意!右侧的数值大小不能超过左侧的类型范围 35 byte num5 = 50; 36 // byte + byte --> int + int --> int 37 int result1 = num4 + num5; 38 System.out.println(result1); // 90 39 40 short num6 = 60; 41 // byte + short --> int + int --> int 42 // int强制转换为short:注意必须保证逻辑上真实大小本来就没有超过short范围,否则会发生数据溢出 43 short result2 = (short) (num4 + num6); 44 System.out.println(result2); // 100 45 } 46 }
转换的注意事项:
- 1. 强制类型转换一般不推荐使用,因为有可能发生精度损失、数据溢出。
- 2. byte/short/char这三种类型都可以发生数学运算,例如加法“+”.
- 3. byte/short/char这三种类型在运算的时候,都会被首先提升成为int类型,然后再计算。
- 4. boolean类型不能发生数据类型转换
1 public class Demo02DataType { 2 public static void main(String[] args) { 3 // 左边是int类型,右边是long类型,不一样 4 // long --> int,不是从小到大 5 // 不能发生自动类型转换! 6 // 格式:范围小的类型 范围小的变量名 = (范围小的类型) 原本范围大的数据; 7 int num = (int) 100L; 8 System.out.println(num); 9 10 // long强制转换成为int类型 11 int num2 = (int) 6000000000L; 12 System.out.println(num2); // 1705032704 13 14 // double --> int,强制类型转换 15 int num3 = (int) 3.99; 16 System.out.println(num3); // 3,这并不是四舍五入,所有的小数位都会被舍弃掉 17 18 char zifu1 = 'A'; // 这是一个字符型变量,里面是大写字母A 19 System.out.println(zifu1 + 1); // 66,也就是大写字母A被当做65进行处理 20 // 计算机的底层会用一个数字(二进制)来代表字符A,就是65 21 // 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字 22 23 byte num4 = 40; // 注意!右侧的数值大小不能超过左侧的类型范围 24 byte num5 = 50; 25 // byte + byte --> int + int --> int 26 int result1 = num4 + num5; 27 System.out.println(result1); // 90 28 29 short num6 = 60; 30 // byte + short --> int + int --> int 31 // int强制转换为short:注意必须保证逻辑上真实大小本来就没有超过short范围,否则会发生数据溢出 32 short result2 = (short) (num4 + num6); 33 System.out.println(result2); // 100 34 } 35 }
四则运算当中的加号“+”有常见的三种用法:
- 1. 对于数值来说,那就是加法。
- 2. 对于字符char类型来说,在计算之前,char会被提升成为int,然后再计算。
- char类型字符,和int类型数字,之间的对照关系表:ASCII、Unicode
- 3. 对于字符串String(首字母大写,并不是关键字)来说,加号代表字符串连接操作。
- 任何数据类型和字符串进行连接的时候,结果都会变成字符串
1 public class Demo05Plus { 2 public static void main(String[] args) { 3 // 字符串类型的变量基本使用 4 // 数据类型 变量名称 = 数据值; 5 String str1 = "Hello"; 6 System.out.println(str1); // Hello 7 8 System.out.println("Hello" + "World"); // HelloWorld 9 10 String str2 = "Java"; 11 // String + int --> String 12 System.out.println(str2 + 20); // Java20 13 14 // 优先级问题 15 // String + int + int 16 // String + int 17 // String 18 System.out.println(str2 + 20 + 30); // Java2030 19 20 System.out.println(str2 + (20 + 30)); // Java50 21 } 22 }
自增运算符:++
自减运算符:--
基本含义:让一个变量涨一个数字1,或者让一个变量降一个数字1
- 使用格式:写在变量名称之前,或者写在变量名称之后。例如:++num,也可以num++
- 使用方式:
- 1. 单独使用:不和其他任何操作混合,自己独立成为一个步骤。
- 2. 混合使用:和其他操作混合,例如与赋值混合,或者与打印操作混合,等。
使用区别:
- 1. 在单独使用的时候,前++和后++没有任何区别。也就是:++num;和num++;是完全一样的。
- 2. 在混合的时候,有【重大区别】
- A. 如果是【前++】,那么变量【立刻马上+1】,然后拿着结果进行使用。 【先加后用】
- B. 如果是【后++】,那么首先使用变量本来的数值,【然后再让变量+1】。 【先用后加】
注意事项:
- 只有变量才能使用自增、自减运算符。常量不可发生改变,所以不能用。
1 public class Demo06Operator { 2 public static void main(String[] args) { 3 int num1 = 10; 4 System.out.println(num1); // 10 5 ++num1; // 单独使用,前++ 6 System.out.println(num1); // 11 7 num1++; // 单独使用,后++ 8 System.out.println(num1); // 12 9 System.out.println("================="); 10 11 // 与打印操作混合的时候 12 int num2 = 20; 13 // 混合使用,先++,变量立刻马上变成21,然后打印结果21 14 System.out.println(++num2); // 21 15 System.out.println(num2); // 21 16 System.out.println("================="); 17 18 int num3 = 30; 19 // 混合使用,后++,首先使用变量本来的30,然后再让变量+1得到31 20 System.out.println(num3++); // 30 21 System.out.println(num3); // 31 22 System.out.println("================="); 23 24 int num4 = 40; 25 // 和赋值操作混合 26 int result1 = --num4; // 混合使用,前--,变量立刻马上-1变成39,然后将结果39交给result1变量 27 System.out.println(result1); // 39 28 System.out.println(num4); // 39 29 System.out.println("================="); 30 31 int num5 = 50; 32 // 混合使用,后--,首先把本来的数字50交给result2,然后我自己再-1变成49 33 int result2 = num5--; 34 System.out.println(result2); // 50 35 System.out.println(num5); // 49 36 System.out.println("================="); 37 38 int x = 10; 39 int y = 20; 40 // 11 + 20 = 31 41 int result3 = ++x + y--; 42 System.out.println(result3); // 31 43 System.out.println(x); // 11 44 System.out.println(y); // 19 45 46 // 30++; // 错误写法!常量不可以使用++或者-- 47 } 48 }