继承:

  1.继承是对某一匹类的抽象,从而实现对现实世界更好的建模。

  2.提高代码的复用性。

  3.extends(扩展),子类是父类的扩展。

  4.子类继承父类可以得到父类的全部属性和方法。(除了父类的构造方法)。

  5.java中只有单继承,没有像c++这种的多继承。多继承就是为了实现代码的复用性,但引入了复杂性,使系统之间的关系造成混乱。

  6.java中的多继承,可以通过接口来实现。

  7.如果定义一个类时,没有调用extends,则默认定义的父类是:Java.lang.Object。

  8.不同的的叫法:超类,父类,基类,子类,派生类。

继承:

代表了一种is-a关系。如果说A是B,也就可以说A继承了B。

父类(SuperClass):更加通用。
* 可以子类中共有的特性和功能保存到父类中
* 优点:提高了代码的复用性。

public class Teacher {
private String name;
private int age;
private int wrokOfYear; public Teacher(String name, int age, int wrokOfYear) {
// super();
this.name = name;
this.age = age;
this.wrokOfYear = wrokOfYear;
} public Teacher() {
// super();
} // getter方法:取值
public String getName() {
return name;
} // setter方法:赋值
public void setName(String name) {
this.name = name;
} public int getAge() {
return age;
} public void setAge(int age) {
this.age = age;
} public int getWrokOfYear() {
return wrokOfYear;
} public void setWrokOfYear(int wrokOfYear) {
this.wrokOfYear = wrokOfYear;
} /**
* 自我介绍
*/
public void intro() {
System.out.println("同学们好,我是" + name + ",今年" + age + "岁,已经工作了" + wrokOfYear + "年");
} /**
* 授课
*/
public void giveLession() {
System.out.println("知识点讲解....");
System.out.println("知识点总结....");
} }

子类:更加具体
* 在java中使用extends关键字实现继承。
* 一旦两个两个类建立了继承关系,子类就可以拥有父类非私有的属性和方法。
* 子类无法继承父类的构造方法,但可以通过super关键字进行调用。
* 语法 [修饰符] class 子类 extends 父类{
*
* }

方法的重写(override):一般发生在子类和父类之间

  1.既可以继承父类的东西又可以灵活的扩充。

  2.其实就是在子类中重新把父类的同名方法重新写一个进行覆盖。

  3.重写方法必须和被重写方法有相同的方法名称,参数列表,返回值。

  4.重写方法不能使用比被重写方法更严格的访问权限。

  5.子类的修饰符范围>=父类的修饰符范围。

重写(override)和重载(overload)的区别:

* 1.重写一般发生在父子之间,重载一般在同一个类中。
* 2.重写要求方法名,返回值类型,参数列表必须与父类相同,并且修饰符范围大于等于父类方法的修饰符范围。
* 重载方法名相同,参数列表不同,与返回值类型及修饰符无关。
* 3.作用不同。
* 重载主要是为了提供一种同名方法不同参数的能力(可以让一个类用于多个同名的方法)
* 重写主要是为了结合多态使用,提高程序扩展性和可维护性。
*
* 注意:一旦子类重写了父类中的方法,创建子类实例后,调用子类重写后的方法。
*
* @Override:重写的注解,标注当前方法为重写父类的方法,必须满足重写的规则。
*/

super:

  是直接父类对象的引用,可以通过 super来调用父类中被子类覆盖的方法和属性。

  super和this其实都是隐式参数,super指当前父类,this指当前。

public class JavaTeacher extends Teacher{
public JavaTeacher(){ }
public JavaTeacher(String name,int age,int workOfYear){
super(name,age,workOfYear);//调用父类的构造方法
} //方法的重写(覆写)
public void giveLession() {
System.out.println("打开eclipse.....");
// System.out.println("知识点讲解.....");
// System.out.println("知识点总结.....");
super.giveLession();//使用super调用父类的方法。
}
}
public class Test {
public static void main(String[] args) {
JavaTeacher javaTeacher = new JavaTeacher("zhangsan",30,6);
javaTeacher.intro();
javaTeacher.giveLession();
System.out.println("************************************");
DBTeacher dbTeacher = new DBTeacher("lisi",33,9);
dbTeacher.intro();
dbTeacher.giveLession();
}
}
public class DBTeacher extends Teacher{
public DBTeacher(){ }
public DBTeacher(String name,int age,int workOfYear){
super(name,age,workOfYear);//调用父类的构造方法
} public void giveLession() {
System.out.println("打开oracle.....");
super.giveLession();//调用父类的方法
}
}

super调用父类中带参数的构造方法同时调用自身的属性进行赋值:

public TestCar(String bland,String size,int price,String color){
super(bland,size,price);
this.color=color;
}

任何类的构造函数中,若是构造函数的第一行代码没有显式的调用super(...);那么Java默认都会调用super();作为父类的初始化函数。 所以你这里的super();加不加都无所谓。

public class AtWill {
public static void main(String[] args) {
Cat c = new Cat(); //---------------(1)
System.out.println("-------------------");
Cat c1 = new Cat("花花",4); //----------------(2)
}
private String color;
private int foot; public AtWill(){
System.out.println("我是父类无参数构造器");
} public AtWill(String color,int foot){
System.out.println("我是父类有参数构造器");
this.color = color;
this.foot = foot;
}
}
class Cat extends AtWill{ public Cat(){
// super(); //---------------可以省略,没有super也自动调用父类无参构造
System.out.println("我是子类无参数构造器");
} public Cat(String color,int foot){
//super(color,foot); //---------------(3)
// super(); //---------------可以省略,调用的父类无参构造
System.out.println("我是子类有参数构造器");
}
}
/**
* 我是父类无参数构造器
我是子类无参数构造器
-------------------
我是父类无参数构造器
我是子类有参数构造器
*/

*java.lang.Object类:所有类的基类
*一个类如果没有显式使用extends继承其他类,这个类继承了Object类,在任何类的对象中使用Object中的方法
*public class Student{
*}
*public class Student extends Object{
*}
*常用的方法:
* getClass() 返回此 Object 的运行时类。主要用于反射机制。
* toString() 返回该对象的字符串表示。如果使用System.out.println(stu);默认调用stu.toString()
* cn.zzsxt.oop6.Student@26ffd553==》
* cn.zzsxt.oop6.Student(包名.类名)+@+16进制表示的hashcode码
* toString()方法经常在子类中重写。
*
*/

public class Student {
String name;
int age;
public Student(){ } public Student(String name,int age){
this.name=name;
this.age=age;
} @Override
public String toString() {
return "Student [name=" + name + ", age=" + age + "]";
} public static void main(String[] args) {
Student stu = new Student("张三",);
// Student stu2 = new Student();
// String str = stu.toString();
// String str2 = stu2.toString();
// System.out.println(str);
// System.out.println(str2);
System.out.println(stu);//默认调用对象的toString();
System.out.println(stu.toString());
}
}

重写object中equals方法:

public class Student {
String name;
int age;
public Student(){ }
public Student(String name,int age){
this.name=name;
this.age=age;
}
/**
* 重写Object中equals方法
*/
@Override
public boolean equals(Object obj) {
Student stu = (Student)obj;  //强转?
if(name.equals(stu.name)&&age==stu.age){
return true;
}else{
return false;
}
} }
/**
* ==和equals的区别
* ==在比较内容时分为以下两种情况:
* 1.使用==比较基本数据类型,做的值的比较,值相同返回true,否则返回false
* 2.使用==比较引用类型,比较不是内容是否相同,而是两个对象的引用(地址)是否相同,
* 如果指向相同的地址返回true,否则返回false。
* equals():比较内容是否相同。
* Object中的equals方法本质比较引用(==),如果需要按照内容进行比较是否相同,就需要重新Object中equals方法。
*/
public class TestEquals {
public static void main(String[] args) {
Student stu = new Student("zhangsan",);
Student stu2 = new Student("zhangsan",);
System.out.println(stu==stu2);//比较stu和stu2是否指向相同的地址。
System.out.println(stu.equals(stu2));//
}
}

父类和子类中代码的执行顺序
* 静态代码块在使用类时执行。
* 普通代码块在创建对象时执行。
* 父类的静态代码块>子类静态代码块>父类的代码块>父类的构造方法>子类的代码块>子类的构造方法
* 在创建子类时,先调用父类的构造方法先创建父类的实例,在创建子类的实例。

public class Child extends Parent{
{
System.out.println("Child....代码块1");
}
static{
System.out.println("Child...static1....");
}
public Child(){
super();
System.out.println("Child()....");
}
{
System.out.println("Child....代码块2");
}
static{
System.out.println("Child...static2....");
} public static void main(String[] args) {
Child child = new Child();
}
}
public class Parent {
{
System.out.println("Parent....代码块");
}
static{
System.out.println("Parent...static1.....");
} public Parent(){
System.out.println("Parent().....");
} {
System.out.println("Parent....代码块2");
}
static{
System.out.println("Parent...static2.....");
} }

Java:面向对象(继承,方法的重写(overide),super,object类及object类中方法的重写,父子类代码块执行顺序)的更多相关文章

  1. java代码块执行顺序

    父类 public class Father { public Father() { System.out.println("父类构造PUBLIC father"); } stat ...

  2. Java中普通代码块,构造代码块,静态代码块执行顺序

    //执行顺序:(优先级从高到低.)静态代码块>mian方法>构造代码块>构造方法. 其中静态代码块只执行一次.构造代码块在每次创建对象是都会执行. 1 普通代码块 1 //普通代码块 ...

  3. 三、Java基础---------关于继承、构造函数、静态代码块执行顺序示例讲解

    在上节博客中曾提到过类的继承,这篇文章主要是介绍类的继承.构造函数以及静态代码块的执行顺序. 首先接着分析在黑马基础测试中的一个关于继承的题目,题目描述如下: 声明类Person,包含2个成员变量:n ...

  4. Java中static代码块,{}大括号代码块,构造方法代码块执行顺序!

    注:下列代码中的注释都是JUnit4单元测试运行结果. 首先,没有父类的(父类是Object)的类A package Static.of; public class A { { System.out. ...

  5. java 过滤器Filter中chain.doFilter()之前和之后代码的执行顺序

    过滤器拦截到响应url的请求后会先执行doFilter()方法中chain.doFilter()之前的代码,然后执行下一个过滤器或者servelt.紧接着执行chain.doFilter()之后的代码 ...

  6. java中的代码块执行顺序

    /* 代码块:在Java中,使用{}括起来的代码被称为代码块. 根据其位置和声明的不同,可以分为 局部代码块:局部位置,用于限定变量的生命周期. 构造代码块:在类中的成员位置,用{}括起来的代码.每次 ...

  7. java中父类子类静态代码块、构造代码块执行顺序

    父类静态(代码块,变量赋值二者按顺序执行) 子类静态 父类构造代码块 父类构造方法 子类构造代码块 子类构造方法 普通方法在实列调用的时候执行,肯定位于上面之后了 //父类A public class ...

  8. Java静态代码块、构造代码块执行顺序问题

    package com.zxl.staticdemo; public class BlockTest { static { System.out.println("BlockTest静态代码 ...

  9. Java面向对象 继承(上)

       Java面向对象 继承 知识概要:         (1)继承的概述 (2)继承的特点 (3)super关键字 (4)函数覆盖 (5) 子类的实例化过程 (6) final关键字 (1)继承 ...

随机推荐

  1. itop4412编译内核时出现“recipe for target 'arch/arm/mach-exynos/cpu-exynos4.o' failed”的解决方法

    依次执行如下命令 #su root 输入root用户密码 #cd #vim .bashrc 到达最底行,确保环境变量如下图所示 保存退出后,执行如下指令 #source .bashrc 重启Termi ...

  2. java——适配器模式、策略模式

    适配器模式: https://www.cnblogs.com/honger/p/5970283.html 策略模式: https://www.jianshu.com/p/3bcf55cf83d3

  3. springboot错误1 Failed to execute goal org.springframework.boot:spring-boot-maven-plugin

    关于Springboot打包错误的问题 | Failed to execute goal org.springframework.boot:spring-boot-maven-plugin https ...

  4. Hibernate 5 开始使用指南前言

    同时在面向对象软件和关系型数据库进行工作,可能会非常复杂和费时.数据在对象和数据库之间可能会不一致,然后导致开发成本会非常高. Hibernate 是一个针对 Java 环境的对象关系映射(Objec ...

  5. 7.6 T1 深度优先搜索(dfs)

    深度优先搜索(dfs) [题目描述] sol:50pts随便写写,就是大众分了,直接n2dpOK,100分要找点规律,需要数学头脑 官方题解 //#include <bits/stdc++.h& ...

  6. WordPress显示评论者IP归属地、浏览器、终端设备、电信运营商

    在网上查资料闲逛,偶然间看到了张戈博客的评论框有点意思,于是就收走拿到了我的米扑博客. 本文为米扑博客原创:总结分享 WordPress显示评论者IP归属地.浏览器.终端设备.电信运营商 WordPr ...

  7. angularJS限制 input-text 只能输入数字

    最初的目的是为了让输入的字段仅为数字,不要包含英文,理所当然想到了正则表达,比起对每一个字符判断ASCII码要方便的多 JS正则表达式的使用,可以参考正则表达式 以match为例,全局匹配非数字 va ...

  8. Java web分级测试评分C级感受

    上周一进行了java分级测试,但是完成的不太好,先看题目: 石家庄铁道大学选课管理系统 1.项目需求: 本项目所开发的学生选课系统完成学校对学生的选课信息的统计与管理,减少数据漏掉的情况,同时也节约人 ...

  9. Android_(控件)使用ListView显示Android系统SD卡的文件列表_02

    使用ListView显示Android SD卡中的文件列表 父类布局activity_main.xml,子类布局item_filelayout(一个文件的单独存放) 运行截图: 程序结构 <?x ...

  10. 关于数据库表设计之区域表system_district:省市县街道四级地址表

    关于省市县的数据表的设计有两种方式: 一.将其设计成一张表 DROP TABLE IF EXISTS `system_district`; CREATE TABLE `system_district` ...