面向对象进阶第三天
内部类
内部类是什么?
- 
类的5大成分(成员变量、成员方法、构造器、代码块、内部类)之一 
- 
类中的类 
使用场景
- 
当一个事物的内部,还有一个部分需要一个完整的结构进行描述时。 
内部类有几种
- 
1、静态内部类 - 
是什么?有static修饰,属于外部类本身。 
- 
特点:只是位置在类里面。类有的成分它都有。 
- 
创建对象: 外部类.内部类名 对象名 = new 外部类名.内部类构造器;
- 
拓展 1、静态内部类可以直接访问外部类的静态成员吗? 可以的 2、静态内部类中是否可以直接访问外部类的实例成员? 不可以的 
 
- 
- 
2、成员内部类(实例内部类) - 
是什么? - 
无static修饰,属于外部类的对象的。 
 
- 
- 
特点:JDK 16中类有的成分,它都有。 
- 
创建对象 : 外部类.内部类 对象名 = new 外部类构造器.new 内部类构造器;
- 
拓展 1、成员内部类中是否可以直接访问外部类的静态成员? 可以 2、成员内部类的实例方法中是否可以直接访问外部类的实例成员? 可以 
 
- 
- 
3、局部内部类 - 
定义在方法,代码块,构造器中,执行代码处的类。鸡肋语法! 
 
- 
- 
4、匿名内部类(重点) - 
使用匿名内部类的好处: - 
方便构建子类对象,最终目的:简化代码 
 
- 
- 
格式: new 类名|接口|抽象类(){
 方法重写;
 }
- 
特点: - 
匿名内部类是一个没有名字的局部内部类,本身也是一个所谓的子类对象。 
- 
匿名内部类产生的对象类型,相当于是当前new的那个的类型的子类类型。 
 
- 
 
- 
枚举
是什么? 是一种特殊类型。 枚举的特征:
- 
枚举类都是继承了枚举类型:java.lang.Enum 
- 
枚举都是最终类,不可以被继承。 
- 
构造器都是私有的,枚举对外不能创建对象。 
- 
枚举类的第一行默认都是罗列枚举对象的名称的。 
- 
枚举类相当于是多例模式。 
泛型
认识泛型
- 
定义类、接口、方法时,同时声明了一个或者多个类型变量(如:<E>) ,称为泛型类、泛型接口,泛型方法、它们统称为泛型。 
- 
作用 - 
泛型提供了在编译阶段约束所能操作的数据类型,并自动进行检查的能力!这样可以避免强制类型转换,及其可能出现的异常。 
 
- 
泛型类
- 
定义类的同时定义了泛型的类就是泛型类 
- 
泛型类的格式 修饰符 class 类名<类型变量,类型变量,…> {
 }
- 
作用 - 
在编译阶段可以指定能操作的数据的类型 
 
- 
- 
原理 - 
把出现泛型变量的地方全部替换成传输的真实数据类型。 
 
- 
泛型接口
- 
使用了泛型定义的接口就是泛型接口 
- 
格式 修饰符 interface 接口名称<泛型变量> {
 }
- 
作用 - 
泛型接口可以让实现类选择当前功能需要操作的数据类型 
 
- 
- 
原理 - 
实现类可以在实现接口的时候传入自己操作的数据类型,这样重写的方法都将是针对于该类型的操作。 
 
- 
泛型方法
- 
定义方法时同时定义了泛型的方法就是泛型方法 
- 
格式 修饰符 <类型变量,类型变量,…> 返回值类型 方法名(形参列表) {
 }
- 
作用 - 
方法中可以使用泛型接收一切实际类型的参数,方法更具备通用性。 
 
- 
- 
原理 - 
把出现泛型变量的地方全部替换成传输的真实数据类型。 
 
- 
泛型通配符、上下限
- 
? 可以在“使用泛型”的时候代表一切类型。 
- 
E T K V 是在定义泛型的时候使用的。 
- 
泛型的上下限 - 
? extends Car: ?必须是Car或者其子类 泛型上限 
- 
? super Car : ?必须是Car或者其父类 泛型下限 
 
- 
泛型的注意事项:擦除问题、基本数据类型问题
- 
泛型是工作在编译阶段的,一旦程序编译成class文件,class文件中就不存在泛型了,这就是泛型擦除。 
- 
泛型不支持基本数据类型,只能支持对象类型(引用数据类型)。 
java.lang包下常用API
API概述
API全称是应用程序编程接口,是Java写好的程序,程序员可以直接调用。
Object类:toString方法
Object是祖宗类,它里面的方法,一切子类对象都可以使用。
public String toString()
- 
默认是返回当前对象的地址信息。 
Student s = new Student("张三",'女', 23);
- 
System.out.println(s.toString());- 
返回对象地址 
 
- 
- 
System.out.println(s);- 
直接输出对象名,默认是调用toString方法的 
 
- 
toString存在的意义:
- 
默认返回对象的地址其实是没有意义的 
- 
真实存在的意义是被子类重写,以便返回子类对象的内容。 
Object类:equals方法
public boolean equals(Object o )
- 
默认是比较2个对象的地址是否一样,返回true 或者false 
equals存在的意义
- 
默认比较对象的地址其实是没有意义的,因为== 号可以更简单的完成 
- 
存在的的真实意义是被子类重写,以便比较对象的内容。 
protected Object clone()
当某个对象调用这个方法时,这个方法会复制一个一模一样的新对象返回。
分类:
- 
浅克隆:拷贝出的新对象,与原对象中的数据一模一样(引用类型拷贝的只是地址) 
- 
深克隆: 对象中基本类型的数据直接拷贝。 对象中的字符串数据拷贝的还是地址。 对象中还包含的其他对象,不会拷贝地址,会创建新对象。 
Objects
Objects是一个工具类,提供了更安全的方式比较2个对象。
Student s = null;
- 
s.equals(s2); 空指针异常 
- 
Objects.equals(s, s2); 返回false 
Objects常见方法:
| 方法名 | 说明 | 
|---|---|
| public static boolean equals(Object a, Object b) | 比较两个对象的,底层会先进行非空判断,从而可以避免空指针异常。再进行equals比较 | 
| public static boolean isNull(Object obj) | 判断变量是否为null ,为null返回true ,反之返回false | 
包装类
其实就是8种基本数据类型对应的引用类型。
作用:实现一切皆对象
包装类的分类:
| 基本数据类型 | 引用数据类型 | 
|---|---|
| byte | Byte | 
| short | Short | 
| int | Integer | 
| long | Long | 
| char | Character | 
| float | Float | 
| double | Double | 
| boolean | Boolean | 
包装类其实可以随便用的:int integer
- 
自动装箱 - 
基本类型的数据可以赋值其给包装类 
 
- 
- 
自动拆箱 - 
包装类的数据赋值给基本数据类型 
 
- 
包装类的特有功能:
1、基本类型变成字符串
// 1、调用包装类继承自Object的toString方法 String rs1 = it6.toString(); // "23" System.out.println(rs1 + 1); // 231  // 2、调用静态方法: public static String toString(int i) String rs2 = Integer.toString(it6);// "23" System.out.println(rs2 + 1);  // 3、直接加 “” String rs3 = it6 + ""; // "23" System.out.println(rs3 + 1);
2、把字符串变成基本数据类型(重点)
String age = "23"; // int ageInt = Integer.parseInt(age); int ageInt = Integer.valueOf(age); System.out.println(ageInt + 1);  String price = "98.5"; // double priceDb = Double.parseDouble(price); double priceDb = Double.valueOf(price); System.out.println(priceDb + 0.5);
 
                    
                
 
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号