第五周
接口
接口的定义
- 接口相当于特殊的抽象类,定义方式、组成部分与抽象类类似
- 使用interface关键字定义接口
- 没有构造方法,不能创建对象
- 只能定义:公开静态常量、公开抽象方法
- 例子
• interface MyInterface{
public static final String FIELD =“Value”;
public abstract void method();
}
- 接口一种标准
- 接口是一种标准
接口与类的异同
- 相同:
- 可编译成字节码文件
- 不能创建对象
- 可以作为引用类型
- 具备Object类中所定义的方法
- 不同
- 所有属性都是公开静态常量,隐式使用public static fianl 修饰
- 所有属性都是公开静态常量,隐式使用 public abstract 修饰
- 没有构造方法、动态代码块、静态代码块
接口的应用
- 什么是接口:
- 微观概念:接口是一种能力和约定
- 接口的定义:代表了某种能力
- 方法的定义:能力的具体要求
- 经验:
- java为单继承,当父类的方法种类无法满足子类需求时,可实现接口扩充子类能力
- 接口支持多实现,可为类扩充多种能力
- 接口的规范
- 任何类在实现接口,必须实现接口中所有的抽象方法,否则此类为抽象
- 实现接口中的抽象方法时,访问修饰符必须是public
- 接口的引用
- 同父类一样,接口也可声明为引用,并指向实现类对象
- 注意
- 仅可调用接口中所声明的方法,不可调用实现类中独有的方法
- 可强转回实现类本身类型,进行独有方法调用
接口的多态
- 例子
• public class TestPolymorpfic{
public static void main(String[] args){Dog myDog = new Dog();
Animal a = myDog;
Runnable r =myDog;
Swimmable s =myDog;}
}
interface Runnale{
public absrtact void run();}
interface Swimmable{
public abstract void swim();}
abstract class Animal{
public void eat(){}//父类方法
public void sleep(){}//父类方法}
class Dog extends Animal implements Runnable ,Swimmable{
public void run(){}//接口方法
public void swim(){]//接口方法
public void shout(){} //独有方法}
• 多种类型的引用指向同一个对象时,表示看待对象的视角不同
• 不同引用所能看到的对象范围不同,只能调用自身类型中所声明的部分
• 不同引用类型,仅可调用自身类型中所声明的方法
接口常见关系
• 类与类
• 单继承
• extends 父类名称
• 类与接口
• 多实现
• implement 接口名称1,接口名称2,接口名称n
• 接口与接口
• 多继承
• extends 父接口1,父接口2,父接口n
接口的规范
• 任何类在实现接口时,必须实现接口中所有的抽象方法,否则此类为抽象类
• 实现接口中的抽象方法时,访问修饰符必须是public
常量接口
• 将多个常用于代表状态或固定值的变量,以将静态常量的形式定义在接口中统一管理,提高代码
接口回调
• 先有接口的使用者,后有接口的实现者
• 接口的回调:先有接口的使用者,后有接口的实现者 程序员:工具的调用 工具:接口的使用者 接口:标准 接口的实现者:程序员
接口的好处:
• 程序的耦合度降低
• 更自然的使用多态
• 设计与实现完全分离
• 更容易搭建程序框架
• 更容易更换具体的实现
常用类:
内部类
• 成员内部类
• 在类的内部定义,与实例变量、实例方法同级别的类
• 外部类的一个实例部分。创建内部类对象时,必须依赖外部类对象
• 当外部类、内部类存在重名属性时,会 优先访问内部类属性
• 成员内部类不能定义静态成员
• 静态内部类
• 不依赖外部类对象,可直接创建或通过类名访问,可声明静态成员
• 只能直接访问外部类的静态成员(实例成员需实例化外部类对象) outer.Inner inner = new Outer.Inner() Outer.Inner.show():
• 局部内部类
• 定义在外部类方法中,作用范围和创建对象范围仅限于当前方法
• 局部内部类访问外部类当前方法中的局部变量时,因无法保障变量的生命周期与自身相同,变量必须修饰为final
• 限制类的使用范围
• 匿名内部类
• 没有类名的局部内部类(一切特征都与局部内部类相同)
• 必须继承一个父类或者实现一个接口
• 定义类、实现类、创建对象的语法合并,只能创建一个该类的对象
• 优点:
• 减少代码量
• 缺点
• 可读性较差
• 内部类的概念:在一个类的内部再定义一个完整的类
• 内部类的特点
• 编译之后可生成独立的字节码文件
• 内部类可直接访问外部类的私有成员,而不破坏封装
• 可为外部类提供必要的内部功能组件
object类
• 超类、基类,所有类的直接或间接父类,位于继续树的最顶层
• 任何类,如果没有书写extends 显示继承某个类,都默认直接继承Object类,否则为间接继续
• Object类中所定义的方法,是所有对象都具备的方法
• Object类型可以存储任何对象
• 作为参数,可接受任何对象
• 作为返回值,可返回任何对象
getClass() 方法
• public fianl Class<?>get Class(){}
• 返回引用中存储的实际对象类型
• 应用:通常用于判断两个引用中实际存储对象类型是否一致
hashCode()方法
• public int hashCode(){}
• 返回该对象的十六进制的哈希码值
• 哈希算法根据对象的地址或字符串或数字计算出来的int类型的数值
• 哈希码并不唯一,可保证相同对象返回相同哈希码,尽量保证不同对象返回不同哈希码
toString()方法
• public String toString(){}
• 返回该对象的字符串表示(表现形式)
• 可以根据程序需求覆盖方法,如:展示对象各个属性值
equals() 方法
• public boolean equals (Object obj){}
• 默认实现为(this==obj),比较两个对象地址是否相同
• 可进行覆盖,比较两个对象的内容是否相同
equals()方法覆盖步骤
• 比较两个引用是否指向同一个对象
• 判断obj 是否为null
• 判断;两个引用指向的实际对象类型是否一致
• 强制类型转换
• 依次比较各个属性值是否相同
finalize()方法
• 当对象被判定为垃圾对象时,由jvn 自动调用此方法,用以标记垃圾对象,进入回收队列
• 垃圾对象 :没有有效引用指向此对象时,为垃圾对象。
• 垃圾回收:由GG销毁垃圾对象,释放数据存储空间
• 自动回收机制:JVM内存耗尽,一次性回收所有垃圾对象
• 手动回收机制:使用System.gc():通知JVM执行垃圾回收
包装类
• 定义:
• 基本数据类型所对应的引用数据类型
• Object可统一所有数据,包装类的默认值是null
• 基本数据类型
类型转换与装箱、拆箱
• 8种包装类提供不同类型间的转换方式
• Numer父类中 提供的6个共性方法
• parseXXX()静态方法
• valueOf()静态方法
• 注意:需包证类型兼容,否则抛出NumberFornamatException异常
• JDK 5.0之后,自动装箱、拆箱。基本数据类型和包装类自动转换
整数缓存区
• java预先创建了256个常用的整数包装类型对象
• 在实际应用当中,对已创建的对象进行复用
String类
• 字符串是常量,创建之后不可改变
• 字符串字面值存储在字符串池,可以共享
• String s =“Hello”;产生一个对象,字符串池中存储
• String s = new String (“Hello”) ;// 产生两个对象,堆、池各存储一个
常用方法
• public char charAt(int index):根据下标获取字符
• public boolean contains(Stirng str):判断当前字符串中是否包含str
• public char[] toCharArray():将字符串转换成数组
• public int indexOf(String str):查找str 首次出现的下标,存在,则返回该下标;不存在。则返回-1
• public int lastIndexOf(Stirng str ):查找字符串在当前字符串中最后一次出现的下标索引
• public int length():返回字符串的长度
• public int length():返回字符串的长度
• public String trim():去掉字符串前后的空格
• public String toUpperCase():将小写转成大写
• public boolean endWith(String str):判断字符串是否以str结尾
• public String replace(char oldChar,char newChar):将字符串替换成新字符串
• public String[] split(String str):根据str做拆分
可变字符串
• StringBuffer:可变长字符串,JDK1.0提供,运行效率慢、线程安全
• StringBuilder:可变长字符串,JDK5.0提供,运行效率快、线程不安全
BigDecimal
• 除法:Bigdecimal(BigDecimal bd ,int scal,RoundingMode mode)
• 参数scal :指定精确到小数点后几位
• 参数mode
• 指定小数部分的取舍模式,通常采用四舍五人的模式
• 取值为BigDecimal.ROUND_HALF_UP
常用类
集合
概念:对象容器。存储对象的对象,可代替数组
特点:容器的工具类 ,定义了多个对象进行操作的常用方法
位置: java.util.*
Collection 体系集合
该体系结构的根接口,代表一组对象成为“集合”
• List
List 接口的特点:有序、有下标、元素可重复• ArrayList
• LinkedList
• Vector
• 子主题 4
• Set
Set 接口的特点:无序、无下标‘、元素不能重复• hashSet
• SortedSet
• TreeSet
Collection 父接口
• 特点:代表一组任意类型的对象,无序、无下标
• 方法
• boolean add(Object obj)//添加一个对象
• boolean addAll(Collection c)//将一个集合中的所有对象添加到此集合中
• void clear() // 清空此集合中的所有对象
• Boolean contains(Object o)//检查此集合中是否包含o 对象
• boolean equals(Object o)// 比较此集合是否与指定对象相等
• boolean isEmpty()// 判断集合是否为空
• Boolean remove(Object o) //在此集合移除0对象
• int size()// 返回此集合中的元素个数
• Object[] toArray()// 将此集合转换成数组
List集合
• List子接口
• 特点:有序、有下标、元素可以重复
• 方法
• void add(int index,Object o) //在index位置插入对象
• boolean addAll(int index ,Coolection c) // 将一个集合中的元素添加到此集合中的index位置
• Object get(int index )// 返回集合中指定位置的元素
• List subList(int fromIndex ,int toIndex) // 返回fromIndex和toIndex之间的集合元素
• List实现类
• ArrayList【重点】
• 数组结构实现,查询快、增删慢
• JDK1.2版本,运行效率快、线程不安全
• 必须开辟连续空间,查询快,增删慢
• Vector
• 数组结构实现,查询快、增删慢
• JDK1.0版本,运行效率慢、线程安全
• LinkedList
• 链表结构实现、增删 快、查询慢
• 无需开辟连续空间,查询慢、增删快
泛式集合
• 概念:参数化类型、类型安全的集合,强制集合元素的类型必须一致
• 特点
• 编译时即可检查,而非运行时抛出异常
• 访问时, 不必类型转换(拆箱)
• 不同泛型之间引用不能相互赋值,泛型不存在多态
Colletions 工具类
• 概念:集合工具类,定义了除了存取以外的集合常用方法
• 方法
• public static void reverse(List<?> list)//反转集合中元素的顺序
• public static void shuffle(List<?> list )// 随机重置集合元素的顺序
• public static void sort(List list) //升序排序(元素类型必须实现 Comparable接口)
Set 集合
• Set子接口
• 特点:无序、无下标、元素不可重复
• 方法:全部继承自Collection中的方法
• Set实现类
• Hash Set【重点】
• 基于HashCode实现元素不重复
• 当存入元素的哈希码相同时,会调用equals进行确认,如结果为true,则拒绝后者存入
• LinkedHashSet
• 链表实现的HashSet,按照链表进行存储,即可保留元素的插入顺序
• TreeSet
• 基于排序顺序实现元素不重复
• 实现了SortedSet接口,对集合元素自动排序
• 元素对象的类型必须实现Comparable接口,指定排序规则
• 通过CompareTo 方法确定是否为重复元素
Map体系集合
• hashMap
• SortedMap
• map接口的特点
• 用于存储任意键值对(Key - value)
• 键:无序、无下标、不允许重复(唯一)
• 值:无序、无下标、允许重复
• Map 父接口
• 特点
• 存储一对数据(key-Value),无序、无下标,键不可重复,值可重复
• 方法:
• V put(K key ,V value )// 将对象存入到集合中。关联键值。key 重复覆盖原值
• Object get(Object key)// 根据键获取对应的值
• Set // 返回包含所有值得Collection集合
• Set<Map.Entry<K,V>>// 键值匹配的Set 集合
• Map集合的实现类
• HashMap【重点】:
• JDK1,2版本,线程不安全,运行效率快;允许用null作为key 或是value
• Hashtable
• JDK1.0版本,线程安全,运行效率慢;不允许null 作为key 或是value
• Properties
• Hashtable的子类,要求key 和value都是String 。通常用于配置文件的读取
• TreeMap
• 实现了SortedMap接口(是Map的子接口),可以对Key 自动排序
总结
集合的概念
- 对象的容器,存储对象的对象,定义了对多个对象进行操作的常用方法
List集合
- 有序、有下标、元素可重复。(ArrayList,LinkedList、Vector)
Set集合
- 无序、无下标、元素不可重复。(HashSet、LinkedList、TreeSet)
Map集合
- 存储一对数据,无序、无下标,键不可重复,值可重复。(hashmap、HashTable)
Collections
- 集合工具类,定义了除了存取以外的集合常用方法
思维导图