Day2---面向对象补充

目录

一、两个小点final,抽象类、抽象方法

1、final

2、抽象类、抽象方法

三、接口


一、两个小点final,抽象类、抽象方法
1、final

(1)修饰变量


    public static void main(String[] args) {
        //第1种情况:
        //final修饰一个变量,变量的值不可以改变,这个变量也变成了一个字符常量,约定俗称的规定:名字大写
        final int A = 10;//final修饰基本数据类型
        //A = 20; 报错:不可以修改值
        //第2种情况:
        final Dog d = new Dog();//final修饰引用数据类型,那么地址值就不可以改变
        //d = new Dog(); -->地址值不可以更改
        //d对象的属性依然可以改变:
        d.age = 10;
        d.weight = 13.7;
        //第3种情况:
        final Dog d2 = new Dog();
        a(d2);
        //第4种情况:
        b(d2);
    }
    public static void a(Dog d){
        d = new Dog();
    }
    public static void b(final Dog d){//d被final修饰 ,指向不可以改变
        //d = new Dog();
    }

(2)修饰方法

         被final修饰方法的话,那么这个方法在子类中不可以被调用。

(3)修饰类

        final修饰类,代表没有子类,该类不可以被继承
       一旦一个类被final修饰,那么里面的方法也没有必要用final修饰了(final可以省略不写)

2、抽象类、抽象方法

(1)抽象类和抽象方法的关系:
抽象类中可以定义0-n个抽象方法。
(2)抽象类作用:
在抽象类中定义抽象方法,目的是为了为子类提供一个通用的模板,子类可以在模板的基础上进行开发,先重写父类的抽象方法,然后可以扩展子类自己的内容。抽象类设计避免了子类设计的随意性,通过抽象类,子类的设计变得更加严格,进行某些程度上的限制。
使子类更加的通用。

//4.一个类中如果有方法是抽象方法,那么这个类也要变成一个抽象类。
//5.一个抽象类中可以有0-n个抽象方法
public abstract class Person {
    //1.在一个类中,会有一类方法,子类对这个方法非常满意,无需重写,直接使用
    public void eat(){
        System.out.println("一顿不吃饿得慌");
    }
    //2.在一个类中,会有一类方法,子类对这个方法永远不满意,会对这个方法进行重写。
    //3.一个方法的方法体去掉,然后被abstract修饰,那么这个方法就变成了一个抽象方法
    public abstract void say();
    public abstract void sleep();
}
//6.抽象类可以被其他类继承:
//7.一个类继承一个抽象类,那么这个类可以变成抽象类
//8.一般子类不会加abstract修饰,一般会让子类重写父类中的抽象方法
//9.子类继承抽象类,就必须重写全部的抽象方法
//10.子类如果没有重写父类全部的抽象方法,那么子类也可以变成一个抽象类。
class Student extends Person{
    @Override
    public void say() {
        System.out.println("我是东北人,我喜欢说东北话。。");
    }
    @Override
    public void sleep() {
        System.out.println("东北人喜欢睡炕。。");
    }
}
class Demo{
    //这是一个main方法,是程序的入口:
    public static void main(String[] args) {
        //11.创建抽象类的对象:-->抽象类不可以创建对象
        //Person p = new Person();
        //12.创建子类对象:
        Student s = new Student();
        s.sleep();
        s.say();
        
        //13.多态的写法:父类引用只想子类对象:
        Person p  = new Student();
        p.say();
        p.sleep();
    }

(3)
..抽象类不能创建对象,那么抽象类中是否有构造器?
抽象类中一定有构造器。构造器的作用  给子类初始化对象的时候要先super调用父类的构造器。

..抽象类是否可以被final修饰?
不能被final修饰,因为抽象类设计的初衷就是给子类继承用的。要是被final修饰了这个抽象类了,就不存在继承了,就没有子类。

二、接口

1、声明格式:
[访问修饰符]  interface 接口名   [extends  父接口1,父接口2…]  {
         常量定义;       
         方法定义;
}

2、代码

/**
 * 1.类是类,接口是接口,它们是同一层次的概念。
 * 2.接口中没有构造器
 * 3.接口如何声明:interface
 * 4.在JDK1.8之前,接口中只有两部分内容:
 * (1)常量:固定修饰符:public static final
 * (2)抽象方法:固定修饰符:public abstract
 * 注意:修饰符可以省略不写,IDE会帮你自动补全,但是初学者建议写上,防止遗忘。
 */
public interface TestInterface01 {
    //常量:
    /*public static final*/ int NUM = 10;
    //抽象方法:
    /*public abstract*/ void a();
    /*public abstract*/ void b(int num);
    /*public abstract*/ int c(String name);
}
interface TestInterface02{
    void e();
    void f();
}
/*
5.类和接口的关系是什么? 实现关系  类实现接口:
6.一旦实现一个接口,那么实现类要重写接口中的全部的抽象方法:
7.如果没有全部重写抽象方法,那么这个类可以变成一个抽象类。
8.java只有单继承,java还有多实现
一个类继承其他类,只能直接继承一个父类
但是实现类实现接口的话,可以实现多个接口
9.写法:先继承 再实现:extends Person implements TestInterface01,TestInterface02
 */
class Student extends Person implements TestInterface01,TestInterface02 {
    @Override
    public void a() {
        System.out.println("---1");
    }
    @Override
    public void b(int num) {
        System.out.println("---2");
    }
    @Override
    public int c(String name) {
        return 100;
    }
    @Override
    public void e() {
        System.out.println("---3");
    }
    @Override
    public void f() {
        System.out.println("---4");
    }
}
class Test{
    //这是一个main方法,是程序的入口:
    public static void main(String[] args) {
        //10.接口不能创建对象:
        //TestInterface02 t = new TestInterface02();
        TestInterface02 t = new Student();//接口指向实现类 ---》多态
        //11.接口中常量如何访问:
        System.out.println(TestInterface01.NUM);
        System.out.println(Student.NUM);
        Student s = new Student();
        System.out.println(s.NUM);
        TestInterface01 t2 = new Student();
        System.out.println(t2.NUM);
    }
}

3、接口的作用?

定义规则,只是跟抽象类不同地方在哪?它是接口不是类。
接口定义好规则之后,实现类负责实现即可。

4、
继承:子类对父类的继承
实现:实现类对接口的实现

5、多态的应用场合:
(1)父类当做方法的形参,传入具体的子类的对象
(2)父类当做方法的返回值,返回的是具体的子类的对象
(3)接口当做方法的形参,传入具体的实现类的对象
(4)接口当做方法的返回值,返回的是具体的实现类的对象

6、接口和抽象类的区别

7、接口中抽象

(1)常量:固定修饰符:public static final
(2)抽象方法:固定修饰符:public abstract 

(3)被public default修饰的非抽象方法:
注意1:default修饰符必须要加上,否则出错
注意2:实现类中要是想重写接口中的非抽象方法,那么default修饰符必须不能加,否则出错

public interface TestInterface {
    //常量:
    public static final int NUM= 10;
    //抽象方法:
    public abstract void a();
    //public default修饰的非抽象方法:
    public default void b(){
        System.out.println("-------TestInterface---b()-----");
    }
}
class Test implements TestInterface{
    public void c(){
        //用一下接口中的b方法:
        b();//可以
        //super.b();不可以
        TestInterface.super.b();//可以
    }
    @Override
    public void a() {
        System.out.println("重写了a方法");
    }
    @Override
    public void b() {
    }
}

(4)静态方法:
注意1:static不可以省略不写
注意2:静态方法不能重写
 

public interface TestInterface2 {
    //常量:
    public static final int NUM = 10;
    //抽象方法:
    public abstract  void a();
    //public default非抽象方法;
    public default void b(){
        System.out.println("-----TestInterface2---b");
    }
    //静态方法:
    public static void c(){
        System.out.println("TestInterface2中的静态方法");
    }
}
class Demo implements TestInterface2{
    @Override
    public void a() {
        System.out.println("重写了a方法");
    }
    public static void c(){
        System.out.println("Demo中的静态方法");
    }
}
class A {
    //这是一个main方法,是程序的入口:
    public static void main(String[] args) {
        Demo d = new Demo();
        d.c();
        Demo.c();
        TestInterface2.c();
    }
}

(5)为什么要在接口中加入非抽象方法?
如果接口中只能定义抽象方法的话,那么我要是修改接口中的内容,那么对实现类的影响太大了,所有实现类都会受到影响。
现在在接口中加入非抽象方法,对实现类没有影响,想调用就去调用即可。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值