【狂神说Java】阶段一笔记20. java面向对象03

封装

/*
 封装(高内聚,低耦合):
    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");
    }
}

PS:学习自狂神说java

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值