18、面向对象(3)
1、权限修饰符
(1)、private:权限:在当前类中可以访问
(2)、default:缺省修饰符:权限:到同一个包下的其他类都可以访问
(3)、protected:权限:最大到不同包下的子类
(4)、public:在整个项目中都可以访问
总结:
属性,方法:修饰符:四种:private,缺省,protected,public
类:修饰符:两种:缺省,public
以后写代码
一般属性:用private修饰 ,方法:用public修饰
2、方法的重写
public class Person {
public void eat(){
System.out.println("吃食物");
}
public void sleep(){
System.out.println("睡觉");
}
}
public class Student extends Person {
public void study(){
System.out.println("学习");
}
@override
public void eat(){
System.out.println("我喜欢吃小龙虾喝啤酒。。");
}
}
public class Test {
//这是一个main方法,是程序的入口:
public static void main(String[] args) {
//创建一个Student类的对象:
Student s = new Student();
s.eat();
}
}
(1)、重写:
发生在子类和父类中,当子类对父类提供的方法不满意的时候,要对父类的方法进行重写。
(2)、重写有严格的格式要求:
子类的方法名字和父类必须一致,参数列表(个数,类型,顺序)也要和父类一致。
(3)、重载和重写的区别:
重载:在同一个类中,当方法名相同,形参列表不同的时候 多个方法构成了重载
重写:在不同的类中,子类对父类提供的方法不满意的时候,要对父类的方法进行重写。
3、super修饰属性,方法
(1)、super:指的是: 父类的
(2)、super可以修饰属性,可以修饰方法;
在子类的方法中,可以通过 super.属性 super.方法 的方式,显示的去调用父类提供的属性,方法。在通常情况下,super.可以省略不写:
(3)、
在特殊情况下,当子类和父类的属性重名时,你要想使用父类的属性,必须加上修饰符super.,只能通过super.属性来调用
在特殊情况下,当子类和父类的方法重名时,你要想使用父类的方法,必须加上修饰符super.,只能通过super.方法来调用
在这种情况下,super.就不可以省略不写。
4、super修饰构造器
(1)、super修饰构造器:
其实我们平时写的构造器的第一行都有:super() -->作用:调用父类的空构造器,只是我们一般都省略不写
(所有构造器的第一行默认情况下都有super(),==但是一旦你的构造器中显示的使用super调用了父类构造器,那么这个super()就不会给你默认分配了。如果构造器中没有显示的调用父类构造器的话,那么第一行都有super(),可以省略不写)
(2)、如果构造器中已经显示的调用super父类构造器,那么它的第一行就没有默认分配的super();了
(3)、在构造器中,super调用父类构造器和this调用子类构造器只能存在一个,两者不能共存:
因为super修饰构造器要放在第一行,this修饰构造器也要放在第一行:
(4)、改正二选一即可:
(5)、以后写代码构造器的生成可以直接使用IDEA提供的快捷键:
alt+insert
5、继承条件下构造方法的执行过程
public class Person {
int age;
String name;
public Person(int age, String name) {
super();
this.age = age;
this.name = name;
}
public Person() {
}
}
public class Student extends Person {
double height ;
public Student() {
}
public Student(int age, String name, double height) {
super(age, name);
this.height = height;
}
}
public class Test {
//这是一个main方法,是程序的入口:
public static void main(String[] args) {
Student s = new Student(19,"霏霏",160.8);
}
}
6、Object类的toString方法
(1)、所有类都直接或间接的继承自Object类,Object类是所有Java类的根基类。也就意味着所有的Java对象都拥有Object类的属性和方法。
如果在类的声明中未使用extends关键字指明其父类,则默认继承Object类。
(2)、Object类的toString()的作用:查看API
(3)、方法的原理:
(4)、
现在,使用toString方法的时候,打印出来的东西 “不好看”,对于其他人来说不友好,可读性不好,我们现在是想知道对象的信息.
(5)、出现的问题:子类Student对父类Object提供的toString方法不满意,不满意–》对toString方法进行重写:
public class Student /*extends Object*/{
private String name;
private int age;
private double height;
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 double getHeight() {
return height;
}
public void setHeight(double height) {
this.height = height;
}
public Student() {
}
public Student(String name, int age, double height) {
this.name = name;
this.age = age;
this.height = height;
}
public String toString() {
return "这是一个Student对象,这个对象的名字:"+name+",年龄:"+age+",身高:"+height;
}
}
测试类:
总结:toString的作用就是对对象进行“自我介绍”,一般子类对父类提供的toString都不满意,都要进行重写。
(6)、
IDEA提供了快捷键:alt+insert
@Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
", height=" + height +
'}';
}
}
7、Object类的equals方法(1)
public class Phone {//手机类:
//属性:
private String brand;//品牌型号
private double price;//价格
private int year ;//出产年份
//方法:
public String getBrand() {
return brand;
}
public void setBrand(String brand) {
this.brand = brand;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
public int getYear() {
return year;
}
public void setYear(int year) {
this.year = year;
}
@Override
public String toString() {
return "Phone{" +
"brand='" + brand + '\'' +
", price=" + price +
", year=" + year +
'}';
}
//构造器:
public Phone() {
}
public Phone(String brand, double price, int year) {
this.brand = brand;
this.price = price;
this.year = year;
}
//对equals方法进行重写:
public boolean equals(Object obj) {//Object obj = new Phone();
//将obj转为Phone类型:
Phone other = (Phone)obj;//向下转型,为了获取子类中特有的内容
if(this.getBrand()==other.getBrand()&&this.getPrice()==other.getPrice()&&this.getYear()==other.getYear()){
return true;
}
return false;
}
}
public class Test {
//这是一个main方法,是程序的入口:
public static void main(String[] args) {
//创建Phone类的对象:
Phone p1 = new Phone("华为P40",2035.98,2020);
Phone p2 = new Phone("华为P40",2035.98,2020);
//比较两个对象:p1和p2对象:
//==的作用:比较左右两侧的值是否想的,要么相等,返回true,要么不相等,返回false
System.out.println(p1==p2);//-->>>对于引用数据类型来说,比较的是地址值。--->一定返回的是false
//Object类提供了一个方法 equals方法 :作用:比较对象具体内容是否相等。
boolean flag = p1.equals(p2);//点进源码发现:底层依旧比较的是==,比较的还是地址值。
System.out.println(flag);
}
}
总结:
equals作用:这个方法提供了对对象的内容是否相等 的一个比较方式,对象的内容指的就是属性。
父类Object提供的equals就是在比较==地址,没有实际的意义,我们一般不会直接使用父类提供的方法,
而是在子类中对这个方法进行重写
8、Object类的equals方法(2)_instanceof
9、Object类的equals方法(3)
(1)、利用eclipse:
(2)、利用idea: