电影网站app怎么做,学科专业网站建设,自己做个影视app需要多少钱,老网站做seo能不能重新注册3.7 方法重写
3.7.1 概念
方法重写 #xff1a;子类中出现与父类一模一样的方法时#xff08;返回值类型#xff0c;方法名和参数列表都相同#xff09;#xff0c;会出现覆盖效果#xff0c;也称为重写或者复写。声明不变#xff0c;重新实现。
3.7.2 使用场景与案例…3.7 方法重写
3.7.1 概念
方法重写 子类中出现与父类一模一样的方法时返回值类型方法名和参数列表都相同会出现覆盖效果也称为重写或者复写。声明不变重新实现。
3.7.2 使用场景与案例
发生在子父类之间的关系。 子类继承了父类的方法但是子类觉得父类的这方法不足以满足自己的需求子类重新写了一个与父类同名的方法以便覆盖父类的该方 法。
例如我们定义了一个动物类代码如下
public class Animal {public void run(){System.out.println(动物跑的很快);}public void cry(){System.out.println(动物都可以叫~~~);}
}
然后定义一个猫类猫可能认为父类cry()方法不能满足自己的需求
代码如下
public class Cat extends Animal {public void cry(){System.out.println(我们一起学猫叫喵喵喵喵的非常好听);}
}
public class Test {public static void main(String[] args) {// 创建子类对象Cat ddm new Cat()// 调用父类继承而来的方法ddm.run();// 调用子类重写的方法ddm.cry();}
}
3.7.2 Override重写注解 Override:注解重写注解校验 这个注解标记的方法就说明这个方法必须是重写父类的方法否则编译阶段报错。 建议重写都加上这个注解一方面可以提高代码的可读性一方面可以防止重写出错 加上后的子类代码形式如下 public class Cat extends Animal {// 声明不变重新实现// 方法名称与父类全部一样只是方法体中的功能重写写了Overridepublic void cry(){System.out.println(我们一起学猫叫喵喵喵喵的非常好听);}
}
3.7.3 注意事项 方法重写是发生在子父类之间的关系。 子类方法覆盖父类方法必须要保证权限大于等于父类权限。 子类方法覆盖父类方法返回值类型、函数名和参数列表都要一模一样。
3.8 继承后的特点—构造方法
3.8.1 引入
当类之间产生了关系其中各类中的构造方法又产生了哪些影响呢 首先我们要回忆两个事情构造方法的定义格式和作用。 构造方法的名字是与类名一致的。所以子类是无法继承父类构造方法的。 构造方法的作用是初始化对象成员变量数据的。所以子类的初始化过程中必须先执行父类的初始化动作。子类的构造方法中默认有一个super() 表示调用父类的构造方法父类成员变量初始化后才可以给子类使用。先有爸爸才能有儿子
继承后子类构造方法器特点:子类所有构造方法的第一行都会默认先调用父类的无参构造方法
3.8.2 案例演示
按如下需求定义类: 人类 成员变量: 姓名,年龄 成员方法: 吃饭 学生类 成员变量: 姓名,年龄,成绩 成员方法: 吃饭
代码如下
class Person {private String name;private int age;
public Person() {System.out.println(父类无参);}
// getter/setter省略
}
class Student extends Person {private double score;
public Student() {//super(); // 调用父类无参,默认就存在可以不写必须再第一行System.out.println(子类无参);}public Student(double score) {//super(); // 调用父类无参,默认就存在可以不写必须再第一行this.score score; System.out.println(子类有参);}
}
public class Demo07 {public static void main(String[] args) {Student s1 new Student();System.out.println(----------);Student s2 new Student(99.9);}
}
输出结果
父类无参
子类无参
----------
父类无参
子类有参
3.8.3 小结 子类构造方法执行的时候都会在第一行默认先调用父类无参数构造方法一次。 子类构造方法的第一行都隐含了一个super()去调用父类无参数构造方法super()可以省略不写。
3.9 super(...)和this(...)
3.9.1 引入
请看上节中的如下案例
class Person {private String name;private int age;
public Person() {System.out.println(父类无参);}
// getter/setter省略
}
class Student extends Person {private double score;
public Student() {//super(); // 调用父类无参构造方法,默认就存在可以不写必须再第一行System.out.println(子类无参);}public Student(double score) {//super(); // 调用父类无参构造方法,默认就存在可以不写必须再第一行this.score score; System.out.println(子类有参);}// getter/setter省略
}
public class Demo07 {public static void main(String[] args) {// 调用子类有参数构造方法Student s2 new Student(99.9);System.out.println(s2.getScore()); // 99.9System.out.println(s2.getName()); // 输出 nullSystem.out.println(s2.getAge()); // 输出 0}
} 我们发现子类有参数构造方法只是初始化了自己对象中的成员变量score而父类中的成员变量name和age依然是没有数据的怎么解决这个问题呢我们可以借助与super(...)去调用父类构造方法以便初始化继承自父类对象的name和age.
3.9.2 super和this的用法格式
super和this完整的用法如下其中thissuper访问成员我们已经接触过了。
this.成员变量 -- 本类的
super.成员变量 -- 父类的
this.成员方法名() -- 本类的
super.成员方法名() -- 父类的
接下来我们使用调用构造方法格式
super(...) -- 调用父类的构造方法根据参数匹配确认
this(...) -- 调用本类的其他构造方法根据参数匹配确认
3.9.3 super(....)用法演示
代码如下
class Person {private String name 凤姐;private int age 20;
public Person() {System.out.println(父类无参);}public Person(String name , int age){this.name name ;this.age age ;}
// getter/setter省略
}
class Student extends Person {private double score 100;
public Student() {//super(); // 调用父类无参构造方法,默认就存在可以不写必须再第一行System.out.println(子类无参);}public Student(String name int agedouble score) {super(name ,age);// 调用父类有参构造方法Person(String name , int age)初始化name和agethis.score score; System.out.println(子类有参);}// getter/setter省略
}
public class Demo07 {public static void main(String[] args) {// 调用子类有参数构造方法Student s2 new Student(张三2099);System.out.println(s2.getScore()); // 99System.out.println(s2.getName()); // 输出 张三System.out.println(s2.getAge()); // 输出 20}
}
注意
子类的每个构造方法中均有默认的super()调用父类的空参构造。手动调用父类构造会覆盖默认的super()。
super() 和 this() 都必须是在构造方法的第一行所以不能同时出现。
super(..)是根据参数去确定调用父类哪个构造方法的。
3.9.4 super(...)案例图解
父类空间优先于子类对象产生
在每次创建子类对象时先初始化父类空间再创建其子类对象本身。目的在于子类对象中包含了其对应的父类空间便可以包含其父类的成员如果父类成员非private修饰则子类可以随意使用父类成员。代码体现在子类的构造七调用时一定先调用父类的构造方法。理解图解如下 3.9.5 this(...)用法演示
this(...) 默认是去找本类中的其他构造方法根据参数来确定具体调用哪一个构造方法。 为了借用其他构造方法的功能。
package com.itheima._08this和super调用构造方法;
/*** this(...):* 默认是去找本类中的其他构造方法根据参数来确定具体调用哪一个构造方法。* 为了借用其他构造方法的功能。**/
public class ThisDemo01 {public static void main(String[] args) {Student xuGan new Student();System.out.println(xuGan.getName()); // 输出:徐干System.out.println(xuGan.getAge());// 输出:21System.out.println(xuGan.getSex());// 输出 男}
}
class Student{private String name ;private int age ;private char sex ;
public Student() {// 很弱我的兄弟很牛逼啊我可以调用其他构造方法Student(String name, int age, char sex)this(徐干,21,男);}
public Student(String name, int age, char sex) {this.name name ;this.age age ;this.sex sex ;}
public String getName() {return name;}
public void setName(String name) {this.name name;}
public int getAge() {return age;}
public void setAge(int age) {this.age age;}
public char getSex() {return sex;}
public void setSex(char sex) {this.sex sex;}
}
3.9.6 小结 子类的每个构造方法中均有默认的super()调用父类的空参构造。手动调用父类构造会覆盖默认的super()。 super() 和 this() 都必须是在构造方法的第一行所以不能同时出现。 super(..)和this(...)是根据参数去确定调用父类哪个构造方法的。 super(..)可以调用父类构造方法初始化继承自父类的成员变量的数据。 this(..)可以调用本类中的其他构造方法。
3.10 继承的特点 Java只支持单继承不支持多继承。
// 一个类只能有一个父类不可以有多个父类。
class A {}
class B {}
class C1 extends A {} // ok
// class C2 extends A, B {} // error 一个类可以有多个子类。
// A可以有多个子类
class A {}
class C1 extends A {}
class C2 extends A {} 可以多层继承。
class A {}
class C1 extends A {}
class D extends C1 {} 顶层父类是Object类。所有的类默认继承Object作为父类。 4. 关于今天知识的小结
会写一个继承结构下的标准Javabean即可
需求
猫属性姓名年龄颜色
狗属性姓名年龄颜色吼叫
分享书写技巧
1.在大脑中要区分谁是父谁是子
2.把共性写到父类中独有的东西写在子类中
3.开始编写标准Javabean从上往下写
4.在测试类中创建对象并赋值调用 代码示例
package com.itheima.test4;
public class Animal {//姓名年龄颜色private String name;private int age;private String color;
public Animal() {}
public Animal(String name, int age, String color) {this.name name;this.age age;this.color color;}
public String getName() {return name;}
public void setName(String name) {this.name name;}
public int getAge() {return age;}
public void setAge(int age) {this.age age;}
public String getColor() {return color;}
public void setColor(String color) {this.color color;}
}
public class Cat extends Animal{//因为猫类中没有独有的属性。//所以此时不需要写私有的成员变量
//空参public Cat() {}
//需要带子类和父类中所有的属性public Cat(String name, int age, String color) {super(name,age,color);}
}
public class Dog extends Animal{//Dog 吼叫private String wang;
//构造public Dog() {}
//带参构造带子类加父类所有的属性public Dog(String name, int age, String color,String wang) {//共性的属性交给父类赋值super(name,age,color);//独有的属性自己赋值this.wang wang;}
public String getWang() {return wang;}
public void setWang(String wang) {this.wang wang;}
}
public class Demo {public static void main(String[] args) {//Animal 姓名年龄颜色//Cat ://Dog 吼叫
//创建狗的对象Dog d new Dog(旺财,2,黑色,嗷呜~~);System.out.println(d.getName(), d.getAge() , d.getColor() , d.getWang());
//创建猫的对象Cat c new Cat(中华田园猫,3,黄色);System.out.println(c.getName() , c.getAge() , c.getColor());}
}