abstract关键字、接口的使用、内部类

本文详细讲解了Java中的abstract关键字,包括其用于修饰抽象类和抽象方法的规则,并强调了抽象类不能实例化。接着介绍了接口的定义、使用方式,以及JDK8新增的静态方法和默认方法特性。通过接口实现多继承,展示了接口在多态性中的应用。此外,文章还探讨了内部类的概念,包括成员内部类的实例化和使用。通过具体的代码示例,解释了如何在接口实现中比较对象,以及接口在实际编程中的应用。
摘要由CSDN通过智能技术生成

面向对象学习最后一天

一叶知秋

一、abstract关键字

1、abstract关键字的使用

  • abstract:抽象的

  • abstract可以用来修饰的结构:类、方法

2、abstract修饰类:抽象类

  • 抽象类不能实例化

  • 抽象类中一定有构造器,便于子类实例化时调用(涉及:子类对象实例化的全过程)

3、abstract修饰方法:抽象方法

  • 抽象方法只有方法的声明,没有方法体

  • 包含抽象方法的类,一定是一个抽象类。反之,抽象类中可以没有抽象方法。

  • 若子类重写了父类中 的所有的抽象方法,此子类方可实例化

    若子类没有重写父类中的所有的抽象方法,则此子类也是一个抽象类,需要使用abstract修饰

4、abstract使用上的注意点

  • abstract不能用来修饰:属性、构造器等结构

  • abstract不能用来修饰私有方法、静态方法、final的方法、final的类

2、接口

1、接口的使用

  • 接口使用interface来定义

  • Java中,接口和类是并列的两个结构

  • 如何定义接口:定义接口中的成员

  • 接口中不能定义构造器,意味着接口不能实例化

  • Java开发中,接口通过让类去实现(implements)的方式来使用

    如果实现类覆盖了接口中的所有抽象方法,则此实现类就可以实例化

    如果实现类没有覆盖接口中所有的抽象方法,则此实现类仍为一个抽象类

  • Java类可以实现多个接口 --->弥补了Java单继承性的局限性

    格式:class AA extends BB implements CC,DD,EE

  • 接口与接口之间可以继承,并且可以多继承

  • 接口的具体使用,体现多态性

  • 接口,实际上可以看做是一种规范

1.1 JDK7及以前:只能定义象方法

全局常量:public static final。但是书写时,可以省略不写。

抽象方法:public abstract

1.1 JDK8:除了定义全局常量和抽象方法之外,还可以定义静态方法、默认方法

  • 接口中定义的静态方法,只能通过接口来调用

  • 通过实现类的对象,可以调用接口中的默认方法

  • 如果实现类重写了接口中的默认方法,调用时,仍然调用的是重写的方法

  • 如果子类(或实现类)继承的父类和实现的接口中声明了同名同参数的方法,那么子类在没有重写此方法的情况下,默认调用的是父类中的同名同参数的方法。--->类优先原则

  • 如果实现类实现了多个接口,而这多个接口中定义了同名同参数的默认方法,那么在实现类没有重写此方法的情况下,报错。--->接口冲突(就需要我们必须在实现类中重写此方法)

三、接口笔试题

 
package Object.Interface;
 //笔试题一:
 ​
 interface A{
     int x = 0;
 }
 ​
 class B{
     int x = 1;
 }
 ​
 public class C extends B implements A {
     public void px(){
         //编译不通过,因为x不明确
 //        System.out.println(x);
         System.out.println(super.x);
         System.out.println(A.x);
     }
 ​
     public static void main(String[] args) {
         new C().px();
     }
 }

注:

如直接输出x,因x不明确,故编译不通过。

若需接口中的x,因其x为全局常量,可利用“类.变量”方式获取;

若需父类中的x,可利用“super.变量”的方式获取父类中的变量。

四、接口练习题

1、题目:

 

2、代码:

 
package Object.Interface.Test1;
 ​
 public interface CompareObject {
     public int compareTo(Object o);
 }
 ​
 public class Circle {
     
     private Double redius;
     
     public Circle(){
     }
 ​
     public Circle(Double redius){
         this.redius = redius;
     }
 ​
     public Double getRedius(){
         return redius;
     }
 ​
     public void setRedius(Double redius){
         this.redius = redius;
     }
 ​
 }
 ​
 public class ComparableCircle extends Circle implements CompareObject{
 ​
     public ComparableCircle(double redius){
         super(redius);
     }
 ​
     @Override
     public int compareTo(Object o) {
         if(this == o){
             return 0;
         }
         if(o instanceof ComparableCircle){
             ComparableCircle c = (ComparableCircle) o;
             //错误的:
 //            return (int) (this.getRedius() - c.getRedius());
             //正确的方式一:
 //            if(this.getRedius() > c.getRedius()){
 //                return 1;
 //            }else if(this.getRedius() < c.getRedius()){
 //                return -1;
 //            }else{
 //                return 0;
 //            }
 ​
             //正确的方式二:
             //当属性redius定义为Double类型时,可以调用包装类的方法
             return this.getRedius().compareTo(c.getRedius());
 ​
         }else{
 //            return 0;
             throw new RuntimeException("传入的数据类型不匹配");
         }
     }
 }
 ​
 public class InterfaceTest {
     public static void main(String[] args) {
 ​
         ComparableCircle c1 = new ComparableCircle(3.4);
         ComparableCircle c2 = new ComparableCircle(3.5);
 ​
         int compareValue = c1.compareTo(c2);
 ​
         if(compareValue > 0){
             System.out.println("c1对象大");
         }else if(compareValue < 0){
             System.out.println("c2对象大");
         }else{
             System.out.println("一样大!");
         }
 ​
         int compareValue1 = c1.compareTo(new String("aa"));
     }
 }

3、结果

 

5、内部类

1、说明

  • Java中允许将一个类A声明在另一个类B中,则类A就是内部类,类B称为外部类

  • 内部类的分类:成员内部类(静态、非静态) vs 局部内部类(方法内、代码块内、构造器内)

2、成员内部类

2.1 作为外部类的成员:

  • 调用外部类的结构

  • 可以被static修饰

  • 可以被四种不同的权限修饰

2.2 作为一个类:

  • 类内可以定义属性、方法、构造器等

  • 可以被final修饰,表示此类不能被继承。言外之意,不使用final就可以被继承。

  • 可以被abstract修饰

3、关注如下的三点

3.1 如何实例化成员内部类的对象

3.2 如何在成员内部类中区分调用外部类的结构

3.3 开发中局部内部类的使用

实例代码如下:

package Object.Interface.Test1;
 ​
 public interface CompareObject {
     public int compareTo(Object o);
 }
 ​
 public class Circle {
     
     private Double redius;
     
     public Circle(){
     }
 ​
     public Circle(Double redius){
         this.redius = redius;
     }
 ​
     public Double getRedius(){
         return redius;
     }
 ​
     public void setRedius(Double redius){
         this.redius = redius;
     }
 ​
 }
 ​
 public class ComparableCircle extends Circle implements CompareObject{
 ​
     public ComparableCircle(double redius){
         super(redius);
     }
 ​
     @Override
     public int compareTo(Object o) {
         if(this == o){
             return 0;
         }
         if(o instanceof ComparableCircle){
             ComparableCircle c = (ComparableCircle) o;
             //错误的:
 //            return (int) (this.getRedius() - c.getRedius());
             //正确的方式一:
 //            if(this.getRedius() > c.getRedius()){
 //                return 1;
 //            }else if(this.getRedius() < c.getRedius()){
 //                return -1;
 //            }else{
 //                return 0;
 //            }
 ​
             //正确的方式二:
             //当属性redius定义为Double类型时,可以调用包装类的方法
             return this.getRedius().compareTo(c.getRedius());
 ​
         }else{
 //            return 0;
             throw new RuntimeException("传入的数据类型不匹配");
         }
     }
 }
 ​
 public class InterfaceTest {
     public static void main(String[] args) {
 ​
         ComparableCircle c1 = new ComparableCircle(3.4);
         ComparableCircle c2 = new ComparableCircle(3.5);
 ​
         int compareValue = c1.compareTo(c2);
 ​
         if(compareValue > 0){
             System.out.println("c1对象大");
         }else if(compareValue < 0){
             System.out.println("c2对象大");
         }else{
             System.out.println("一样大!");
         }
 ​
         int compareValue1 = c1.compareTo(new String("aa"));
     }
 }
 package Object.Interface;
 ​
 public class InnerClassTest1 {
 ​
     //开发中很少见
     public void method(){
         //局部内部类
         class AA{
 ​
         }
     }
 ​
     public Comparable getComparable() {
 ​
         //创建一个实现了Comparable接口的类:局部内部类
         //方式一:
 //        class MyComparable implements Comparable{
 //
 //            @Override
 //            public int compareTo(Object o) {
 //                return 0;
 //            }
 //        }
 //        return new MyComparable();
 //    }
 //}
 ​
         //方式二:
         return new Comparable() {
             @Override
             public int compareTo(Object o) {
                 return 0;
             }
         };
     }}

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值