深度解析: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,只 ...
随机推荐
- 虚拟环境与local_settings
虚拟环境(virtualenv) 对于同时管理多个不同的项目时,使用虚拟环境是必须的. 虚拟环境就是用来为一个项目新建一个全新的纯净的python运行环境,该环境与系统的python环境相互隔离,且虚 ...
- update不能直接使用select的返回结果
update不能直接使用select的返回结果,这是会报错的,这是SQL的语法规定的,若想在update中与select结合使用,sql需要这样写: 1.其中field1,field2为表中的字段名 ...
- Lambda表达式(二)
Lambda表达式是给函数式接口(SAM接口)的变量或形参赋值的表达式.Lambda表达式替代了原来使用匿名内部类的对象给函数式接口(SAM接口)的变量或形参赋值的形式. 匿名内部类:实现了这个接口, ...
- 使用Node.js原生API写一个web服务器
Node.js是JavaScript基础上发展起来的语言,所以前端开发者应该天生就会一点.一般我们会用它来做CLI工具或者Web服务器,做Web服务器也有很多成熟的框架,比如Express和Koa.但 ...
- Zookeeper学习大块分类
Zookeeper是一个典型的发布/订阅模式的分布式数据管理与协调框架,开发人员可以使用它来进行分布式数据的发布与订阅.另一方面,通过对Zookeeper 丰富的数据节点类型进行交叉使用,配合Watc ...
- MVC框架的代码审计小教程
介绍 YxtCMF在线学习系统是一个以thinkphp+bootstrap为框架进行开发的网络学习平台系统. 在线学习系统,为现代学习型组织提供了卓有成效的学习与培训方案, 能够通过在线学习和在线评估 ...
- JavaScript监听滚动条的进度条
<style type="text/css"> *{ margin: 0; padding: 0; } .g-box{ width: 100%; height: 400 ...
- nginx反向代理三台web服务器,实现负载均衡
修改nginx.conf #在http和server之间加入这个模块 upstream guaji{ server 127.0.0.1:8080; server 127.0.0.2:8080; ser ...
- DES 实现
原理 加密 置换: IP逆置换: 迭代: PC-1置换: PC-2置换: 子秘钥的生成: 加密函数f: 解密 代码 // C语言实现 #include<stdio.h> #include& ...
- 【杂谈】JS相关的线程模型整理
1.JS是单线程吗? 是的,到目前为止,JS语言没有多线程的语法,它的执行引擎只支持单线程,也就是一个JavaScript进程内只有一个线程. 2.事件循环什么? 事件循环就是执行线程不断的从队列中取 ...