深度解析:java必须掌握的知识点——类的重用
类继承的概念和语法
类继承的概念
根据已有类来定义新类,新类拥有已有类的所有功能。
Java只支持类的单继承,每个子类只能有一一个直接超类(父类)。
超类是所有子类的公共属性及方法的集合,子类则是超类的特殊化。
继承机制可以提高程序的抽象程度,提高代码的可重用性。
超类和子类
子类对象与超类对象存在“是一个…”或“是一种…”的关系。
子类对象
从外部来看,它应该包括
与超类相同的接口
可以具有更多的方法和数据成员
其内包含着超类的所有变量和方法
继承的语法
[ClassModifier] class ClassName extends SuperClassName
{
//类体
}
类继承举例
设有三个类: Person(人), Employee(员工),Manager(管理人员)。很明显:Person是范围最广的一个,Employee次之,Manager的范围最小,其类层次如图:
有如下代码:
Preson.java
public class Person {
public String name;
public String getName() {
return name;
}
}
Employee.java
public class Employee extends Person {
public int employeeNumber;
public int getEmployeeNumber() {
return employeeNumber;
}
}
Manager.java
public class Manager extends Employee {
public String responsibilities;
public String getResponsibilities() {
return responsibilities;
}
}
可以看出Employee(员工)是一种特殊的Person(人),所以Employee继承于Person类。而Manager(管理人员)是一种特殊的Employee(员工),所以Manager继承于Employee类。
下面为测试类:
public class Test {
public static void main(String args[]){
Employee li = new Employee();
li.name = "Li Ming";
li.employeeNumber = 123456;
System.out.println(li.getName());
System.out.println(li.getEmployeeNumber());
Manager he = new Manager();
he.name = "He Xia";
he.employeeNumber = 543469;
he.responsibilities = "Internet project" ;
System.out.println(he.getName());
System.out.println(he.getEmployeeNumber());
System.out.println(he.getResponsibilities());
}
}
类中定义了一个Employee类li,输出li的名字和编号
一个Manager类he,输出he的名字,编号和职责。
运行结果:
属性的隐藏
有以下代码:
class Parent {
Number aNumber;
}
class Child extends Parent
Float aNumber;
}
子类中声明了与超类中相同的成员变量名
从超类继承的变量将被隐藏
子类拥有了两个相同名字的变量,一个继承自超类,另-一个由自己声明
当子类执行继承自超类的操作时,处理的是继承自超类的变量,而当子类执行它自己声明的方法时,所操作的就是它自己声明的变量
那么如果子类想要访问被隐藏的属性该怎么办?
访问被隐藏的超类属性调用从超类继承的方法,则操作的是从超类继承的属性
本类中声明的方法使用"super.属性”访问从超类继承的属性
假设有两个类A1和B1
class A1{
int x= 2;
public void setx(int i){
x=i;
}
void printa(){
System.out.println(x);
}
} class B1 extends A1 {
int x=100;
void printb(){
super.x = super.x +10 ;
System.out.println("super.x=" +
super.x+" x=" + x);
}
}
之后运行测试代码:
public class Test {
public static void main(String args[]){
A1 a1=new A1();
a1.setx(4);
a1.printa(); B1 b1 = new B1();
b1.printb();
b1.printa(); b1.setx(6); // 将继承x值设置为6
b1.printb();
b1.printa(); a1.printa();
}
}
运行结果:
方法覆盖
如果子类不需使用从超类继承来的方法的功能,则可以声明自己的同名方法,称为方法覆盖
覆盖方法的返回类型,方法名称,参数的个数及类型必须和被覆盖的方法一模一样
只需在方法名前面使用不同的类名或不同类的对象名即可区分覆盖方
法和被覆盖方法
覆盖方法的访问权限可以比被覆盖的宽松,但是不能更为严格
方法覆盖的应用场合
子类中实现与超类相同的功能,但采用不同的算法或公式;
在名字相同的方法中,要做比超类更多的事情;
在子类中需要取消从超类继承的方法。
方法覆盖的注意事项:
必须覆盖的方法
派生类必须覆盖基类中的抽象的方法,否则派生类自身也成为抽象类.
不能覆盖的方法
基类中声明为final的终结方法基类中声明为static的静态方法
调用被覆盖的方法
super.overriddenMethodName();
Object类
所有类的直接或间接超类,处在类层次最高点;
包含了所有Java类的公共属性。
Object类的主要方法
public final Class getClass()
获取当前对象所属的类信息,返回Class对象。
public String toStringO
返回表示当前对象本身有关信息的字符串对象。
public boolean equals(Object obj)
比较两个对象引用是否指向同一对象,是则返回true ,否则返回false。
protected Object clone()
复制当前对象,并返回这个副本。
public int hashCode()
返回该对象的哈希代码值。
protected void finalize() throws Throwable
在对象被回收时执行,通常完成的资源释放工作。
终结类与终结方法
用final修饰的类和方法;
终结类不能被继承;
终结方法不能被子类覆盖。
抽象类
类名前加修饰符abstract ;
可包含常规类能包含的任何成员,包括非抽象方法;
也可包含抽象方法:用abstract修饰,只有方法原型,没有方法的实现;
没有具体实例对象的类,不能使用new方法进行实例化,只能用作超类;
只有当子类实现了抽象超类中的所有抽象方法,子类才不是抽象类,才能产生实例;
如果子类中仍有抽象方法未实现,则子类也只能是抽象类。
抽象类声明的语法形式
abstract class Number {
}
如果写new Number()将会编译错误。
抽象方法
声明的语法形式为:
public abstract <returnType> <methodName>(..);
仅有方法原型,而没有方法体;
抽象方法的具体实现由子类在它们各自的类声明中完成;
只有抽象类可以包含抽象方法。
抽象方法的优点
隐藏具体的细节信息,所有的子类使用的都是相同的方法原型,其中包含了调用该方法时需要了解的全部信息;
强迫子类完成指定的行为,规定所有子类的"标准”行为。
类的组合
组合的语法
将已存在类的对象放到新类中即可
例如,可以说"厨房( kitchen)里有一个炉子( cooker )和一一个冰箱( refrigerator )”。所以,可简单的把对象myCooker和myRefrigerator放在类Kitchen中:
class Cooker{ 类的语句}
class Refrigerator{ 类的语句}
class Kitchen{
Cooker myCooker;
Refrigerator myRefrigerator;
}
例:组合举例——线段类
一条线段包含两个端点
public class Point //点类
{
private int x, y; //coordinate
public Point(int x, int y){ this.x = x; this.y = y;}
public int GetX() { return x; }
public int GetY( { return y; }
}
class Line //线段类
{
private Point p1,p2; // 两端点
Line(Point a, Point b) {
p1 = new Point(a.GetX(),a.GetY());
p2 = new Point(b.GetX(),b.GetY());
}
public double Length() {
return Math.sqrt(Math.pow(p2.GetX(-p1.GetX0,2)
+ Math.pow(p2.GetY0)-p1.GetY0.2));
}
}
一个线段类包含两个端点,也就是组合了两个点类。
总结:看完有什么不懂的欢迎在下方留言评论,记得点个赞哦!
深度解析:java必须掌握的知识点——类的重用的更多相关文章
- 深度解析Java 8:JDK1.8 AbstractQueuedSynchronizer的实现分析
深度解析Java 8:JDK1.8 AbstractQueuedSynchronizer的实现分析(上) 深度解析Java 8:AbstractQueuedSynchronizer的实现分析(下) A ...
- 深度解析 Java 内存原型
一.Java 虚拟机内存原型 寄存器:我们在程序中无法控制. 栈:存放基本类型的数据和对象的引用,但对象本身不存放在栈中,而是存放在 堆中. 堆:存放用 new 产生的数据. 静态域:存放在对象中用 ...
- 深度解析Java内存原型
一.Java 虚拟机内存原型 寄存器:我们在程序中无法控制. 栈:存放基本类型的数据和对象的引用,但对象本身不存放在栈中,而是存放在堆中. 堆:存放用new产生的数据. 静态域:存放在对象中用stat ...
- 深度解析Java多线程的内存模型
内部java内存模型 硬件层面的内存模型 Java内存模型和硬件内存模型的联系 共享对象的可见性 资源竞速 Java内存模型很好的说明了JVM是如何在内存里工作的,JVM可以理解为java执行的一个操 ...
- 深度解析Java可变参数类型以及与数组的区别
注意:可变参数类型是在jdk1.5版本的新特性,数组类型是jdk1.0就有了. 这篇文章主要介绍了Java方法的可变参数类型,通过实例对Java中的可变参数类型进行了较为深入的分析,需要的朋友可以参考 ...
- 深度解析Java中的5个“黑魔法”
现在的编程语言越来越复杂,尽管有大量的文档和书籍,这些学习资料仍然只能描述编程语言的冰山一角.而这些编程语言中的很多功能,可能被永远隐藏在黑暗角落.本文将为你解释其中5个Java中隐藏的秘密,可以称其 ...
- 深入源码,深度解析Java 线程池的实现原理
java 系统的运行归根到底是程序的运行,程序的运行归根到底是代码的执行,代码的执行归根到底是虚拟机的执行,虚拟机的执行其实就是操作系统的线程在执行,并且会占用一定的系统资源,如CPU.内存.磁盘.网 ...
- 深度解析Java中的那把锁
锁的本质 我们先来讨论锁的出现是为了解决什么问题,锁要保证的事情其实很好理解,同一件事(一个代码块)在同一时刻只能由一个人(线程)操作. 这里所说的锁为排他锁,暂不考虑读写锁的情况 我们在这里打个比方 ...
- Java 8 Optional 类深度解析
Java 8 Optional 类深度解析 身为一名Java程序员,大家可能都有这样的经历:调用一个方法得到了返回值却不能直接将返回值作为参数去调用别的方法.我们首先要判断这个返回值是否为null,只 ...
随机推荐
- 手撸了一个HTTP框架:支持Sprng MVC、IOC、AOP,拦截器,配置文件读取...
https://github.com/Snailclimb/jsoncat :仿 Spring Boot 但不同于 Spring Boot 的一个轻量级的 HTTP 框架 距离上一次给小伙伴们汇报简易 ...
- byte + byte = int
byte+byte=int,低级向高级是隐式类型转换,高级向低级必须强制类型转换,byte<char<short<int<long<float<double
- 没事学些KVM(三)虚拟机基础管理
创建完成虚拟机后,需要对虚拟机进行基础管理学习 virsh list #查看虚拟机列表 改命令只能查看正在运行或挂起的虚拟机 如果需要查看所有的虚拟机需要添加--all 参数 virsh start ...
- elasticsearch启动报错
1,max file descriptors [4096] for elasticsearch process is too low, increase to at least [65536] 查看 ...
- JVM详解(二)-- 第2章 类加载器子系统
一.JVM内存结构 1.1 内存结构---概略图 1.2 内存结构--详细图 二.类加载器子系统的作用 类加载器子系统负责从文件系统或网络中加载.Class文件,文件需要有特定的标识(cafe bab ...
- Jmeter 获取系统时间
${__time(yyyy-MM-dd HH:mm:ss:SSS,time)} :格式化生成时间格式 2020-11-03 21:59:13:658
- php的三元运算符
简单记录一哈php的三元运算符的用法: 啥子是三元运算,即第一个表达式作为判断条件,在后面两个表达式中选择一个执行. 若判断成立,则执行第二个表达式,否则执行第三个表达式. 看到好多网友都说的不 ...
- [Luogu P3469] [POI2008]BLO-Blockade (割点)
题面 传送门:https://www.luogu.org/problemnew/show/P3469 Solution 先跟我大声念: poi! 然后开始干正事. 首先,我们先把题目中的点分为两类:去 ...
- 转载:解密Redis持久化
本文内容来源于Redis作者博文,Redis作者说,他看到的所有针对Redis的讨论中,对Redis持久化的误解是最大的,于是他写了一篇长文来对Redis的持久化进行了系统性的论述.文章非常长,也很值 ...
- uniapp微信小程序分享
触发代码 如: <button open-type="share">分享</button> 在JS中 分享进入页面传参,和微信小程序路由传参的思路是一样的. ...