封装
/*
封装(高内聚,低耦合):
1.提高程序的安全性,保护数据
2.隐藏代码的实现细节
3.统一接口
4.系统可维护性增加了
*/
public class Application {
public static void main(String[] args) {
Student s1 = new Student();
s1.setName("qinjiang");
System.out.println(s1.getName());
s1.setAge(-1); //通过方法修改属性,方法不为静态,无法通过类调用,即无法修改属性默认值
System.out.println(s1.getAge());
}
}
public class Student {
//属性私有
private String name;
private int id;
private char sex;
private int age;
//提供一些可以操作这个属性的方法, 提供一些public的get、set方法
public String getName(){
return this.name;
}
public void setName(String name){
this.name = name;
}
//方法快捷键:alt + insert -> Getter and Setter
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public char getSex() {
return sex;
}
public void setSex(char sex) {
this.sex = sex;
}
public int getAge() {
return this.age;
}
public void setAge(int age) {
if (age > 120 || age < 0){
this.age = 3;
}else{
this.age = age;
}
}
}
继承
public class Application {
public static void main(String[] args) {
Student student = new Student();
// student.say();
// Person person = new Person();
// person.getClass();
//
// student.test("秦将");
// student.test1();
}
}
/*
super注意点:
1.super调用父类的构造方法,位置必须在构造方法的第一个
2.super必须只能出现在子类的方法或者构造方法中!
3.super和this不能同时调用构造方法,因为this也必须在构造方法的第一个!
Vs this:
代表的对象不同:
this:本身调用者这个对象
super:代表父类对象的应用
前提
this:没有继承也可以使用
super:只能在继承者中才可以使用
构造方法:
this():本类的构造
super():父类的构造
*/
//人:父类
//在Java中,所有的类都默认直接或间接继承Object,Java只有单继承
public class Person /*extends Object*/ {
//public 公共的
//default
//protected
//private 私有的,无法继承,用于属性
private int money = 10_0000_0000;
protected String name = "kuangshen";
public Person(){
System.out.println("Person无参执行了");
}
//私有的无法被继承
public void print(){
System.out.println("Person");
}
public void say(){
System.out.println("说了一句话");
}
public int getMoney() {
return money;
}
public void setMoney(int money) {
this.money = money;
}
}
//Teacher is 人:派生类,子类
public class Teacher extends Person{
}
//学生 is 人: 派生类, 字类
//子类继承了父类,就会拥有父类的全部方法
public class Student extends Person{
//Ctrl + H 打开继承树结构
private String name = "qinjiang";
public Student(){
//隐藏代码:调用了父类的无参构造
super(); //调用父类的构造器必须要在子类的第一行
System.out.println("Student无参执行了");
}
public void test(String name){
System.out.println(name); //秦将
System.out.println(this.name); //qinjiang
System.out.println(super.name); //kuangshen
}
public Student(String name){
this.name = name;
}
@Override
public void print(){
System.out.println("Student");
}
public void test1(){
print(); //Student
this.print(); //Student
super.print(); //Person
}
}
重写
public class Application {
//静态方法和非静态的方法区别很大
public static void main(String[] args) {
//静态方法:方法的调用只和左边,定义的数据类型有关
//非静态方法:重写,只能是public
A a = new A();
a.test(); //A => test()
//父类的引用b指向了子类a
B b = new A(); //子类重写了父类的方法,重写只与非静态方法有关
b.test(); //B => test()
}
}
/*
重写:需要有继承关系,子类重写父类的方法!
1.方法名必须相同
2.参数列表必须相同
3.修饰符:父类到子类范围可以扩大但不能缩小,public > protected > default > private
4.抛出的异常:父类到子类范围可以被缩小但不能扩大,ClassNotFoundException -> Exception(大)
重写,子类的方法和父类必须要一致,方法体不同
为什么需要重写:
1.父类的功能,子类不一定需要,或者不一定满足!
2.Alt + Insert -> override;
*/
//重写都是方法的重写,和属性无关
public class B {
public void test(){
System.out.println("B => test()");
}
}
public class A extends B{
@Override //注解:有功能的注释
public void test() {
System.out.println("A => test()");
}
}
多态
public class Application {
public static void main(String[] args) {
//一个对象的实际类型是确定的
//可以指向的引用类型就不确定了:父类的引用指向子类
//Student能调用的方法都是自己的或者继承父类的
Student s1 = new Student();
//Person 父类型,可以指向子类,但是不能调用子类独有的方法
Person s2 = new Student();
Object s3 = new Student();
s2.run(); //子类重写了父类的方法,执行子类的方法
s1.run();
//对象能执行那些方法,主要看对象左边的类型,和右边关系不大!
s1.eat();
((Student) s2).eat();
}
}
/*
多态:
同一方法可以根据发送对象的不同而采取多种不同的行为方式
一个对象的实际类型是确定的,但可以指向对象的引用类型有很多(父类,有关系的类)
多态注意事项:
1.多态是方法的多态,属性没有多态
2.父类和子类,有联系 否则触发类型转换异常 ClassCastException
3.多态存在的条件:继承关系,方法需要重写,父类的引用指向子类对象 Father f1 = new Son();
4.static方法属于类,不属于实例,不能被重写
5.final是常量,也不能被重写
6.private修饰的方法是私有的,也不能被重写
*/
public class Person {
public void run(){
System.out.println("run");
}
}
public class Student extends Person{
@Override
public void run() {
System.out.println("son");
}
public void eat(){
System.out.println("ear");
}
}