1.抽象类和抽象方法

  1. 抽象方法,仅有方法声明没有方法体

    abstract class AbstractClass{
    abstract void f(); //没有 {} }
  2. 只要有一个或者多个抽象方法,则必是抽象类,抽象类可以没有抽象方法。
  3. 抽象类内可以没有抽象方法,也可以只有实现的方法。
    abstract class AbstractClass{
    
        void g(){
    System.out.println("hello");
    }
    }
  4. 抽象类可以有自己各种权限的字段和方法,但抽象方法一定是public或者protected的,因为抽象类的抽象方法生来就是要被继承重写的。
  5. 继承抽象类,要覆写抽象类内的所有抽象方法,提供方法体,如果不提供方法体那么这个子类也是抽象类,前面要将加关键字
  6. 抽象类可以有静态代码块和非静态代码块。

2.接口

  1. 接口内没有任何具体实现,没有一个方法体。

    public
    interface Runnable { public abstract void run();
    }
  2. 接口中的方法默认public权限
  3. 接口中可以有成员变量,但被隐性设定为 static 和  final
  4. 接口中不能有代码块和静态代码块
  5. 接口权限和类一样也有public,但必须在同名文件中

3.协变类型:

  • 子类中被覆写的方法返回类型可以是父类方法返回值的子类型
class A {

}

class B extends A {

}

abstract class AbstractClass {

    abstract A g();

}

class C extends AbstractClass {
//返回值类型是A类型
// A g(){
// return null;
// }
//g() 返回值类型是A类型的子类型B也可以覆写
B g() { return null; }
}

4.多重继承

4.1 接口 extends 接口 , 接口,接口,. . .

4.2 类 extends 接口,接口,接口, . . .

4.3 类 extends 类   implements 接口,接口,接口, . . .

4.4 类 implements  接口,接口,接口, . . .

  • 实现多个接口,这些接口中应该避免有相同的方法名

5.嵌套接口

  • 接口可以嵌套在类中或者其他接口中

5.1 把嵌套的接口/类在A类外部看作A类的数据成员,在A类内部就看做正常的接口/类

5.2 类中嵌套的类或者接口权限可以是private

5.3 由于接口中的方法默认public,所以在接口中的接口不能被声明为private

5.4 嵌套中的 private接口 作用就是 让这个private接口中的方法无返回类型,不能向上转型

class A {
public class Ain{ }
//内部的类权限可以设定为private
private class Ain2{ }
public interface Aface{ }
private interface Aface2{
void f(); //必须返回空值
} }

6.接口和抽象类和适配器模式

  • 一个类直接实现接口就要实现接口中的所有方法,但有时并不想实现所有方法就可以使用适配器模式。
  • 使用抽象类可以分离【接口实现】 和 接口, 接口实现可以有选择的实现接口中的部分方法,这就是适配器模式
  • 适配器设计模式

7.接口和抽象类区别

  1. 语法区别如上
  2. 设计区别:抽象类是对一种事物的抽象,即对类抽象,而接口是对行为动作的抽象
  3. 这篇博客写的非常详细推荐

《Java编程思想》笔记 第九章 接口的更多相关文章

  1. java编程思想笔记(第一章)

    Alan Kay 第一个定义了面向对象的语言 1.万物皆对象 2.程序是对象的集合,他们彼此通过发送消息来调用对方. 3.每个对象都拥有由其他对象所构成的存储 4.每个对象都拥有其类型(TYpe) 5 ...

  2. Java编程思想笔记(第二章)

    第二章  一切都是对象 尽管Java是基于C++的,但相比之下,Java是一种更纯粹的面向对象程序设计语言. c++和Java都是杂合型语言(hybird language) 用引用(referenc ...

  3. Java编程思想——第17章 容器深入研究 读书笔记(三)

    七.队列 排队,先进先出. 除并发应用外Queue只有两个实现:LinkedList,PriorityQueue.他们的差异在于排序而非性能. 一些常用方法: 继承自Collection的方法: ad ...

  4. Java编程思想——第17章 容器深入研究(two)

    六.队列 排队,先进先出.除并发应用外Queue只有两个实现:LinkedList,PriorityQueue.他们的差异在于排序而非性能. 一些常用方法: 继承自Collection的方法: add ...

  5. Java编程思想 第21章 并发

    这是在2013年的笔记整理.现在重新拿出来,放在网上,重新总结下. 两种基本的线程实现方式 以及中断 package thread; /** * * @author zjf * @create_tim ...

  6. Java编程思想 笔记

    date: 2019-09-06 15:10:00 updated: 2019-09-24 08:30:00 Java编程思想 笔记 1. 四类访问权限修饰词 \ 类内部 本包 子类 其他包 publ ...

  7. java编程思想笔记(1)

    java编程思想笔记(1) 一,对象的创建和生命周期 对象的数据位于何处?怎样控制对象的生命周期? 在堆(heap)的内存池中动态地创建对象. java完全采用了动态内存分配方式. 二,垃圾回收器 自 ...

  8. #Java编程思想笔记(一)——static

    Java编程思想笔记(一)--static 看<Java编程思想>已经有一段时间了,一直以来都把笔记做在印象笔记上,今天开始写博客来记录. 第一篇笔记来写static关键字. static ...

  9. 2.1(java编程思想笔记)位移操作

    java位移操作主要有两种: 有符号位移:有符号位移会保留原有数字正负性,即正数依然是正数,负数依然是负数. 有符号位左移时,低位补0. 有符号右移时:当数字为正数,高位补0.当数字为负时高位补1. ...

随机推荐

  1. NO11——01背包

    # include <stdio.h> # include <stdlib.h> # include <string.h> # define max(x,y) x& ...

  2. poj1789 Truck History最小生成树

    Truck History Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 20768   Accepted: 8045 De ...

  3. JQuery JTable根据某行的某个值来设置行的背景颜色

    目录 描述 处理方法 参考 描述 某个表的数据是用JQuery的JTable插件进行展示的.现在需求是:当表中的master字段为true时,就将对应的整行的背景颜色设置为浅蓝色. 处理方法 在fie ...

  4. 【Linux】Linux修改openfile和max user processes?

    #当时测试虚机为centos7.4版本: # 在/etc/security/limits.conf文件末尾添加如下命令: *     soft     nproc   1314 *     hard  ...

  5. 【转载】Linux升级NTPD服务器-编译安装ntp-4.2.8p12与配置

    [转载]Linux升级NTPD服务器-编译安装ntp-4.2.8p12与配置 1. 系统与软件版本 1.1 系统版本 rhel6.4(Red Hat Enterprise Linux Server r ...

  6. 【bzoj3191】[JLOI2013]卡牌游戏 概率dp

    题目描述 n个人围成一圈玩游戏,一开始庄家是1.每次从m张卡片中随机选择1张,从庄家向下数个数为卡片上的数的人,踢出这个人,下一个人作为新的庄家.最后一个人获胜.问每个人获胜的概率. 输入 第一行包括 ...

  7. hdu 3500 Fling (dfs)

    Fling Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submi ...

  8. [bzoj1052] [HAOI2007]覆盖问题

    Description 某人在山上种了N棵小树苗.冬天来了,温度急速下降,小树苗脆弱得不堪一击,于是树主人想用一些塑料薄膜把这些小树遮盖起来,经过一番长久的思考,他决定用3个L * L的正方形塑料薄膜 ...

  9. SCU3037 Painting the Balls

    Description Petya puts the \(N\) white balls in a line and now he wants to paint some of them in bla ...

  10. P2765 魔术球问题(网络流24题)

    题目描述 «问题描述: 假设有n根柱子,现要按下述规则在这n根柱子中依次放入编号为1,2,3,...的球. (1)每次只能在某根柱子的最上面放球. (2)在同一根柱子中,任何2个相邻球的编号之和为完全 ...