JAVA中抽象类和方法的重写

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

@[TOC]JAVA中抽象类和方法的重写


前言

1、用abstract关键字来定义的类叫抽象类,abstract关键字定义的方法叫抽象方法,抽象方法在的类一定要定义为抽象类,而且抽象类必须被继承,这样才能实现对抽象方法的重写。
2、抽象类不能被实例化,只需声明,不用实现。
3、方法的重写:
条件一 两个类必须有继承关系
条件二 重写后的方法必须和父类的方法具有:
(1)相同的返回值类型
(2)相同的方法名
(3)相同的形参列表,也就是参数个数和类型都一致
条件三 重写的方法的访问权限不能更低


一、定义抽象类

public abstract class Person {
    /*注意:抽象类中的抽象方法没有大括号*/
    public abstract void show(String name,int age);
}


二、定义实现类(也就是子类)

//        Student类继承了Person类
public   class Student {
//      重写了Person类中的show方法,方法名相同,返回值相同,形参列表相同
        public  void show(String name,int age) {
            System.out.println(name+age);
    }
}


三、访问修饰符

重写的方法的访问权限不能更低的意思是因为子类是从父类那里继承来的,子类意义上可以替换父类能出现的地方,并且不影响代码的运行,如果子类重写的方法访问权限低于父类的方法,那么会导致在某一些地方不能实现该方法,例如:父类的抽象方法访问修饰符是public,而子类的重写方法的访问修饰符是private,子类的方法只能在本类中使用,不能在其他类或者包外使用,而父类的方法却是公开的,可以在任何地方访问,这就违反了“子类可以替换父类能出现的地方”。
(按自己的理解啰里啰唆讲了这么多,不晓得有没有表达清楚,哈哈哈。参考的里氏代换原则,如果有错误的,请各位大佬指正,谢谢谢谢)
Java常用的四种访问修饰符权限:
public>protected>default(默认)>private

public abstract class Person {
   //父类的抽象方法设了protected访问修饰符
    protected abstract void show(String name,int age);
}

在这里插入图片描述


总结

(1)抽象类是出于定义的时候不知道这个类具体的工作或者业务,只知道这个类大概用来干什么的。
(2)抽象类中可以没有抽象方法,编译器也不报错,当然如果不放抽象方法,定义抽象类意义也不大。

Java抽象类抽象方法是面向对象编程的重要概念之一。抽象类是一个不能被实例化的类,它用于定义一组相关的具体子类的共同特征和行为。抽象方法是在抽象类声明但没有具体实现的方法抽象类通过关键字"abstract"来声明,可以包含普通的成员变量、普通的成员方法抽象方法抽象方法使用"abstract"关键字进行声明,并且不包含具体的实现。抽象方法必须在具体的子类重写实现。 抽象类的主要作用是为了模板化和规范化一组相关的子类。它可以提供一些通用的方法和属性,同时规定了子类必须实现的抽象方法,从而强制子类保持一定的一致性。 下面是一个简单的例子来说明抽象类抽象方法的使用: ```java abstract class Shape { protected String color; public Shape(String color) { this.color = color; } public abstract double getArea(); public void display() { System.out.println("This is a shape with color: " + color); } } class Circle extends Shape { private double radius; public Circle(String color, double radius) { super(color); this.radius = radius; } @Override public double getArea() { return Math.PI * radius * radius; } } class Rectangle extends Shape { private double width; private double height; public Rectangle(String color, double width, double height) { super(color); this.width = width; this.height = height; } @Override public double getArea() { return width * height; } } public class Main { public static void main(String[] args) { Circle circle = new Circle("Red", 5.0); circle.display(); System.out.println("Area of circle: " + circle.getArea()); Rectangle rectangle = new Rectangle("Blue", 3.0, 4.0); rectangle.display(); System.out.println("Area of rectangle: " + rectangle.getArea()); } } ``` 在这个例子抽象类`Shape`定义了一个抽象方法`getArea()`,所有的具体子类必须实现该方法。子类`Circle`和`Rectangle`继承自抽象类`Shape`,分别实现了自己的`getArea()`方法。在`main()`方法,我们创建了一个圆和一个矩形对象,并调用它们的`display()`和`getArea()`方法来展示抽象类抽象方法的使用。 需要注意的是,由于抽象类不能被实例化,所以我们不能直接创建抽象类的对象。但是我们可以通过具体的子类来创建对象,并调用抽象类方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值