【Java不看后悔系列】|面向对象编程|[继承、封装、多态全覆盖]

简介: 【Java不看后悔系列】|面向对象编程|[继承、封装、多态全覆盖]


1.Judging right from wrong

(inheritance)

1.A child class inherits everything from its parent class.

2.A child class cannot inherit the constructors from its parent class .

子类继承的内容:

字段(成员变量):

子类会继承父类的字段,包括实例变量和静态变量。子类可以直接访问继承而来的字段。

方法:

子类会继承父类的方法,包括实例方法和静态方法。子类可以直接调用继承而来的方法。

子类可以重写(override)父类的方法,以提供特定于子类的实现。

构造方法:

如果子类没有定义构造方法,它会默认调用父类无参构造方法(如果父类有的话)。

如果子类定义了构造方法,可以使用 super 关键字调用父类的构造方法。

接口的实现:

如果父类实现了某个接口,子类也会继承该接口的实现,除非子类明确地重新实现了该接口。

子类不继承的内容:

私有成员

子类不会继承父类中的私有成员(私有字段、私有方法)

构造方法:

子类继承父类的构造方法但是,子类可以通过使用 super 调用父类的构造方法来初始化继承的部分。

父类的静态成员:

子类不会继承父类的静态成员静态成员与类关联的,而不是与对象关联的

父类的构造方法私有属性:

如果父类的构造方法是私有的,子类不能直接调用父类的构造方法。这通常会限制子类对父类构造方法的继承。

在Java中,子类会继承其父类的一些特性,但并非所有内容都会被继承。---> F,F


3.The superclass’s constructor must be explicitly invoked in the subclass’s constructor.

在Java中,当你在子类中创建构造函数时,通常需要显式调用超类的构造函数使用super关键字来实现。如果在子类构造函数中没有显式调用超类构造函数,Java将隐式插入对超类默认(无参)构造函数的调用。

下面是一个示例,说明了这个概念:

class Superclass {
    // Default constructor---无参构造方法
    public Superclass() {
        System.out.println("Superclass default constructor");
    }
    // Parameterized constructor---含参构造方法
    public Superclass(int x) {
        System.out.println("Superclass parameterized constructor with x = " + x);
    }
}
class Subclass extends Superclass {
    // Implicit call to the default constructor of the superclass
    // if this constructor doesn't explicitly call a superclass constructor
    public Subclass() {
        //这里隐含super()
        System.out.println("Subclass constructor");
    }
    // Explicit call to the parameterized constructor of the superclass
    public Subclass(int y) {
        super(y); // Call to the parameterized constructor of the superclass
        System.out.println("Subclass constructor with y = " + y);
    }
}
public class Main {
    public static void main(String[] args) {
        Subclass obj1 = new Subclass();
        Subclass obj2 = new Subclass(10);
    }
}

子类Subclass在无参构造函数(Subclass())中隐式调用了超类Superclass的默认构造函数。在有参构造函数(Subclass(int y))中,通过使用super(y)显式调用了超类的带参数构造函数。

值得注意的是,如果超类没有默认构造函数,并且在子类构造函数中没有显式调用超类构造函数,那么将会引发编译错误。因为Java子类构造函数第一条语句

要么是使用super显式调用超类构造函数

要么是隐式调用超类的默认构造函数


2.selection

Questions  refer to the BankAccount, SavingsAccount, and CheckingAccountclasses defined below:

(Constructor,inheritance)

1. Of the methods shown, how many different nonconstructor methods can be invoked by a SavingsAccount object? ---> 找SavingAccount调用的非构造方法的个数

(A) 1   (B) 2  (C) 3   (D) 4  (E)5

因为我们之前已经学过什么是构造方法什么是继承,并且知道继承会继承父类的方法,若有遗忘点击👉🔗:http://t.csdnimg.cn/MZtBH

so 是4个--->D

调用父类构造方法的语句super()必须位于子类构造方法语句的句首。

2. Which is a correct implementation of the constructor with parameters in the SavingsAccount class?  

A:  不可以直接给父类私有变量直接赋值,对于父类的私有变量需要通过父类提供public的构造方法进行变量修改。

B:有getbalance只是返回balance的值,并不是把它的值给balance所以B不正确。

C:super();只是调用父类无参构造方法,balance = 0;

但是并未将accountBlance赋值给balance,所以错误

E: 父类不含两个参数构造方法,无法调用。

C:想要执行SavingsAccount class的含参构造方法,去修改参数的值,在子类可以 直接通过=赋值进行修改,而对于父类的私有变量需要通过父类提供public的构造方法进行变量修改。

如果父类类变量是private,要访问/修改父类私有变量,需要父类提供public的构造方法进行变量修改 --->D


📝总结:

在Java中,final 关键字有不同的用途,它可以用于变量、方法以及类。

1.Final 修饰变量:

当 final 用于修饰一个变量时,表示该变量是一个常量,其值不能被修改。这一次赋值后,就不能再次为该变量赋新值。

final int x = 10;

2.Final 修饰方法:

当 final 用于修饰一个方法时,表示该方法不能被子类重写(覆盖)。

public class Parent {
       public final void display() {
           System.out.println("This method cannot be overridden.");
       }
   }

3.Final 修饰类:

当 final 用于修饰一个类时,表示该类不能被继承,即不能有子类

final class FinalClass {
       // Class implementation
   }

使用 final 的好处包括:

安全性: 当一个变量被声明为 final 时,它的值不能被改变,这样可以防止在程序的其他部分意外地改变这个值。

性能优化: Java 编译器能够进行一些优化,因为它知道 final 变量的值在运行时不会发生变化,这可以在某些情况下提高性能。

设计上: final 方法和类可以阻止子类修改其行为,这有助于确保一些设计上的意图。

需要注意的是,final 并不是总是必需的,而是根据设计需要和代码安全性来决定是否使用。在合适的情况下使用 final 可以提高代码的清晰性和可维护性。

目录
相关文章
|
20天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
15 3
|
20天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
29 2
|
20天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
27 2
|
20天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
27 1
|
24天前
|
存储 Java 测试技术
Java零基础-多态详解
【10月更文挑战第10天】Java零基础教学篇,手把手实践教学!
19 4
|
29天前
|
Java 编译器 程序员
Java多态背后的秘密:动态绑定如何工作?
本文介绍了Java中多态的实现原理,通过动态绑定和虚拟方法表,使得父类引用可以调用子类的方法,增强了代码的灵活性和可维护性。文中通过具体示例详细解析了多态的工作机制。
34 4
|
1月前
|
Java 测试技术 编译器
Java零基础-继承详解!
【10月更文挑战第4天】Java零基础教学篇,手把手实践教学!
33 2
|
1月前
|
Java 编译器
在Java中,关于final、static关键字与方法的重写和继承【易错点】
在Java中,关于final、static关键字与方法的重写和继承【易错点】
21 5
|
1月前
|
Java
java继承和多态详解
java继承和多态详解
41 5
|
1月前
|
存储 Java 测试技术
Java零基础-多态详解
【10月更文挑战第1天】Java零基础教学篇,手把手实践教学!
25 1