Java的抽象类

当父类的某些方法需要声明,但是又不确定如何实现时,可以将其声明为抽象方法,那么这个类就是抽象类

java 复制代码
package com.abstract_;

public class Abstract01 {
    public static void main(String[] args) {

    }
}
//class Animal{
//    private String name;
//    public Animal(String name) {
//        this.name = name;
//    }
//    //当父类的某些方法需要声明,但是又不确定如何实现时,可以将其声明为抽象方法,那么这个类就是抽象类
//    public void eat(){
//        //这里的方法体内不确定要写什么,例如不确定动物都吃些什么
//    }
//}

abstract class Animal{  //声明为抽象类
    private String name;
    public Animal(String name) {
        this.name = name;
    }
    public abstract void eat(); //声明为抽象方法
}
复制代码
父类方法不确定性问题
1.考虑将该方法设计为抽象(abstract)类
2.所谓抽象方法就是没有实现的方法
3.所谓没有实现就是指,没有方法体
4.当一个类中存在抽象方法时,需要将该类声明为abstract
5.一般来说,抽象类会被继承,由其子类来实现

抽象类的介绍:

1)用abstract 关键字来修饰一个类时,这个类就叫抽象类

访问修饰符 abstract 类名{

}

2)用abstract关键字修饰一个方法时,这个方法就是抽象方法

访问修饰符 abstract 返回类型 方法名(形参列表); //没有方法体

3)抽象类的价值更多作用是在于设计,是设计者设计好后,让子类继承并实现抽象类

4)抽象类在框架和设计模式中使用较多

抽象类使用的注意事项和细节讨论:

1)抽象类不能被实例化

2)抽象类不一定要包含abstract方法,也就是说,抽象类可以没有abstract方法

3)一旦类包含了abstract方法,则这个类必须声明为abstract

4)abstract只能修饰类和方法,不能修饰属性和其他的

5)抽象类可以有任意成员(因为抽象类也是类),比如非抽象方法,构造器,静态属性等等

6)抽象方法不能有主体,即不能实现

/

7)如果一个类继承了抽象类,则它必须实现抽象类的所有方法,除非它自己也声明为abstract类

java 复制代码
//如果一个类继承了抽象类,则它必须实现抽象类的所有方法,除非它自己也声明为abstract类
abstract class E{
    public abstract void hi();
}
abstract class F extends E {
}
class G extends F{
    @Override
    public void hi() {
        System.out.println("泥嚎");//只要有大括号就可以成为实现,哪怕方法体内什么也没有
    }
}

8)抽象方法不能用private,final,static修饰,因为这些关键字都适合重写相违背的(重要)

习题:

java 复制代码
package com.abstract_;

public class AbstractExercise {
    public static void main(String[] args) {
        Employee commonEmployee = new CommonEmployee("张三","123",15000);
        Employee Manage = new Manager("李四","456",50000);

        System.out.println(commonEmployee.work());
        System.out.println(Manage.work());
    }
}
//编写一个Employee类,声明为抽象类,包含下面三个属性:name,id,salary.
//提供必要的构造器和抽象方法,work().对于Manager来说,他既是员工,还具有奖金(bonus)属性.
//请使用继承的思想,设计CommonEmployee类和Manager类
//要求类中提供必要的方法进行属性访问,实现work(),提示:"经理/普通员工 名字 工作中....."
abstract class Employee{
    private String name;
    private String id;
    private double salary;


    public Employee(String name, String id, double salary) {
        this.name = name;
        this.id = id;
        this.salary = salary;
    }

    public abstract String work();

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public double getSalary() {
        return salary;
    }

    public void setSalary(double salary) {
        this.salary = salary;
    }
}
class CommonEmployee extends Employee{
    public CommonEmployee(String name, String id, double salary) {
        super(name, id, salary);
    }

    @Override
    public String work() {
        return "普通员工" + super.getName() + "工作中......";
    }
}
class Manager extends Employee{
    private double bonus;

    public Manager(String name, String id, double salary) {
        super(name, id, salary);
    }

    public double getBonus() {
        return bonus;
    }

    public void setBonus(double bonus) {
        this.bonus = bonus;
    }

    @Override
    public String work() {
        return "经理" + super.getName() + "工作中......";
    }
}
相关推荐
皮皮林5517 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河7 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程10 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅12 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者13 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺13 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart14 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP15 小时前
MyBatis-mybatis入门与增删改查
java
孟陬19 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端