2.3 java基础 day04 构造方法 继承 多态 方法重载 方法重写 递归 访问权限 内部类

目录

构造方法:

继承:

多态:

方法重载:

方法重写

递归:

访问权限:

内部类:


构造方法:

  • 用于构建对象,在 new 对象的时候调用执行
  •         如果一个类中没有任何构造方法,JVM 会自动添加一个 公共的、无参的 构造方法,方便对象调用
  •         类名 () { xxx }
  •         构造方法也是方法,但是没有 void 关键字
  •          方法和类名完全相同
  •         构造方法也可以传递参数,一般用于对象属性的赋值
  • 代码块 比构造方法先执行
public class Java11_Object_Instance {
    public static void main(String[] args) {

        // TODO 面向对象 - 构建对象
        // 构造方法:专门用于构建对象
        // 如果一个类中没有任何的构造方法,那么JVM会自动添加一个公共的,无参的构造方法,方便对象的调用
        // TODO : 基本语法: 类名(){}
        //  1. 构造方法也是方法,但是没有void关键字。
        //  2. 方法名和类名完全 相同
        //  3. 如果类中没有构造方法,那么JVM会提供默认的构造方法
        //  4. 如果类中有构造方法,那么JVM不会提供默认的构造方法
        //  5. 构造方法也是方法,所以也可以传递参数,但是一般传递参数的目的是用于对象属性的赋值
        //System.out.println("before...");
        User11 user = new User11("zhangsan");
        //System.out.println("after...");
        user.test();
        System.out.println(user.username);
        // 代码块,是在构造对象之前执行的

    }
}
class User11 {
    String username;

    {
        System.out.println("代码块1");
    }

    User11(String name) {
        username = name;
        System.out.println("user...");
    }
    {
        System.out.println("代码块2");
    }
    void test() {
        System.out.println("test...");
    }
    {
        System.out.println("代码块3");
    }
}

继承:

面向对象编程 3 个重要特征:继承、封装、多态

  • 类存在父子关系,子类可以直接获取父类的成员属性和成员方法,提高开发效率,有利于代码维护升级
  • 类的继承只能是单继承,一个类只能有一个父类,但一个父类可以有多个子类
  • 子类 extends 父类
  • 如果父类和子类含有相同的属性,那么可以采用特殊的关键字进行区分:super、this,都表示对象
  • 构造方法:
  1.  父类对象是在子类对象创建前创建完成,创建子类对象前,会调用父类的构造方法完成父类的创建
  2. 默认情况下,子类对象构建时,会默认调用父类的构造方法完成父类对象的创建。使用的是super的方式,只不过JVM自动完成(无参构造方法)
  3. 如果父类提供构造方法,那么JVM不会提供默认的构造方法,那么子类应该显示调用super方法构建父类对象。
  4. new 只会构建一个对象,在内存中只会开辟一块空间存储创建的对象
    public class java11_object_extends {
        public static void main(String[] args) {
            Child c =new Child();
            c.test();
        }
    }
    class Parent{
        String name="dongzhuo";
        void test(){
            System.out.println("名字:"+name);
        }
    }
    class Child extends Parent{
    
    }
    public class Java12_Object_Extends_1 {
        public static void main(String[] args) {
    
            // TODO 面向对象 - Extends - 继承
            // 如果父类和子类含有相同的属性,那么可以采用特殊的关键字进行区分
            // super & this.
            Child1 c = new Child1();
            //System.out.println(c.name);
            c.test();
    
        }
    }
    class Parent1 {
        String name = "zhangsan";
    }
    class Child1 extends Parent1 {
        String name = "lisi";
        void test() {
            System.out.println(super.name);//父类的name
            System.out.println(this.name);//子类的name
            System.out.println(name);
        }
    }
    

    构造方法的继承

    public class Java12_Object_Extends_2 {
        public static void main(String[] args) {
    
            // TODO 面向对象 - Extends - 继承
            // 构造方法
            // 父类对象是在子类对象创建前创建完成,创建子类对象前,会调用父类的构造方法完成父类的创建
            // 默认情况下,子类对象构建时,会默认调用父类的构造方法完成父类对象的创建。使用的是super的方式,只不过JVM自动完成
            // 如果父类提供构造方法,那么JVM不会提供默认的构造方法,那么子类应该显示调用super方法构建父类对象。
            Child2 c1 = new Child2();
            Child2 c2 = new Child2();
            Child2 c3 = new Child2();
    
        }
    }
    class Parent2 {
        String username;
    
        Parent2 (String name) {
            username = name;
            System.out.println("parent...");
        }
    }
    class Child2 extends Parent2 {
    
        Child2() {
            super("zhangsan");
            System.out.println("child...");
        }
    }
    

    多态:

  • 所谓的多态,其实就是一个对象在不同场景下表现出来的不同状态和形态
  • 多态语法其实就是对对象的使用场景进行了约束
  • 一个对象可以使用的功能取决于引用变量的类型
  • 当 使用父类声明、创建子类对象的时候,子类的方法不可用(父类和子类方法重名时可以用子类的方法)
  1. public class Java13_Object {
        public static void main(String[] args) {
    
            // TODO 面向对象 - 多态
            // 所谓的多态,其实就是一个对象在不同场景下表现出来的不同状态和形态
            // 多态语法其实就是对对象的使用场景进行了约束
            // 一个对象可以使用的功能取决于引用变量的类型
            Person p = new Person();
            p.testPerson();
            Person p1 = new Boy();
            p1.testPerson();
            //p1.testBoy();
            Person p2 = new Girl();
            p2.testPerson();
            //p2.testGirl();
    
            Boy boy = new Boy();
            boy.testBoy();
    
            Girl girl = new Girl();
            girl.testGirl();
        }
    }
    
    class Person {
        void testPerson() {
            System.out.println("test person...");
        }
    }
    class Boy extends Person {
    
        void testBoy() {
            System.out.println("test boy...");
        }
    }
    class Girl extends Person {
    
        void testGirl() {
            System.out.println("test girl...");
        }
    }
    

 

方法重载:

  • 一个类中不能重复声明相同的方法/属性
  • 这里相同的方法是指 方法名、参数列表相同,和返回值类型无关
  • **重载:**如果方法名相同,但参数列表(个数,顺序,类型)不相同,会认为是不同的方法,只不过名称一样
  • 构造方法也存在方法重载,如:new User(xxx)
  • 如果在一个构造方法中,想要调用其他的构造方法,那么需要使用特殊的关键字:this
  • 基本数据类型在匹配方法时,可以在数值不变的情况下扩大数据精度
  • byte类型无法和char类型做转换,char没有负数,但byte有负数
     

 普通方法重载和构造方法重载

public class Java14_Object {
    public static void main(String[] args) {

        // TODO 面向对象
        // 一个类中,不能重复声明的相同的方法,也不能声明相同的属性
        // 这里相同的方法指的是方法名,参数列表相同,和返回值类型无关
        // 如果方法名相同,但是参数列表(个数,顺序,类型)不相同,会认为是不同的方法,只不过名称一样
        // 这个操作在Java称之方法的重载
        // 构造方法也存在方法的重载
        User14 user = new User14("zhangsan");
        user.login(1111);
        user.login("123123");
        user.login("zhangsan", "123123");

    }
}
class User14 {

    User14() {
        System.out.println("user...");
    }
    User14(String name) {
        System.out.println("user..." + name);
    }

    void login( String account, String password ) {
        System.out.println("账号,密码登录");
    }
    void login(int tel) {
        System.out.println("手机验证码登录");
    }
    void login(String wx) {
        System.out.println("微信,支付宝登录");
    }
}

 构造方法重载调用另外构造方法

public class Java14_Object_1 {
    public static void main(String[] args) {

        // TODO 面向对象
        // 如果在一个构造方法中。想要调用其他的构造方法,那么需要使用特殊的关键字:this
        User141 user1 = new User141();
        //User141 user2 = new User141("zhangsan");
        //User141 user3 = new User141("zhangsan", "男");
    }
}
class User141 {
    User141() {
        this("zhangsan");
    }
    User141( String name ) {
        this(name, "男");
    }
    User141( String name, String sex ) {
        System.out.println(name + "," + sex);
    }
}

 基本数据类型在匹配方法时,可以在数值不变的情况下扩大数据精度

public class Java14_Object_2 {
    public static void main(String[] args) {

        // TODO 面向对象
        byte b = 10;
       // test(b); bbb
        // int => iii
        // byte => 8
        // short => 16
        // char => 16
        // int => 32
        // 基本数据类型在匹配方法时,可以在数值不变的情况下,扩大数据的精度
        // byte类型无法和char类型做转换,char没有负数,但是byte存在负数

       // test(b);
    }
    
//    static void test( byte b ) {
//        System.out.println("bbb");
//    }
//    static void test( short s ) {
//        System.out.println("sss");
//    }
    static void test( char c ) {
        System.out.println("ccc");
    }
//    static void test( int i ) {
//        System.out.println("iii");
//    }
}

 


方法重写

  • 父类对象的方法主要体现通用性,无法在特殊场合下使用,如果子类对象需要在特殊场合下使用,就需要重写方法的逻辑
  • 重写并不意味着父类的方法被覆盖,只是当前场合不适用,使用super还是可以访问
  • **重写要求:**子类方法和父类方法方法名相同、返回值类型相同、参数列表相同
  • 构造方法不能重写
  • 一个对象方法的具体使用(直接、间接)是需要看具体对象的
  • 一个对象属性的具体使用不需要看具体对象,属性在哪里声明在哪里使用

        注:子类没有找父类(就那么简单)

public class java18_fulei {
    public static void main(String[] args) {
//        Parent18 p1=new Parent18();
//        p1.test();
        Parent18 p2=new Child18();
        p2.test();
    }
}
class Parent18{
    int i=10;
    void test(){

        System.out.println(i+10);
    }
}
class Child18 extends Parent18{
//    int i=11;
    void test(){
        System.out.println(i+20);
    }
}

 

public class Java15_Object {
    public static void main(String[] args) {

        // TODO 面向对象 - 重写
        // 方法的重写:父类对象的方法其实主要体现通用性,无法在特殊的场合下使用
        //           如果子类对象需要在特殊的场合下使用,那么就需要重写方法的逻辑,这个操作在Java中称之为方法的重写
        // 这里的重写,并不意味着父类的方法被覆盖掉,只是在当前场合不使用。如果使用super关键字还是可以访问
        // 方法的重写要求,子类的方法和父类的方法,方法名相同,返回值类型相同,参数列表要相同
        Child15 child = new Child15();
        child.test();
    }
}
class Parent15 {
    String name = "zhangsan";

    void test() {
        System.out.println("parent test...");
    }
}
class Child15 extends Parent15 {
    String name = "lisi";

    @Override
    void test() {
//        System.out.println(this.name);
//        System.out.println(super.name);
        super.test();
        System.out.println("child test...");
    }
}

递归:

  •  方法调用自身(阶乘等)

  • 方法要有跳出的逻辑,注意 StackOverflowError 异常

  • 调用自身时,传递的参数要有规律

public class java20_jieceng {
    public static void main(String[] args) {
        int result=computed(5);
        System.out.println(result);
    }
    public static int computed(int num) {
        
         if (num==1){
             return 1;
         }else{
             return num*computed(num-1);
         }
    }
}

访问权限:

public : 公共的,访问权限修饰符

Java的源码中,公共类只能有一个,而且必须和源码文件名相同

main方法:main方法是由JVM调用的,JVM调用时应该可以任意调用,而不用考虑权限问题。

Java中的访问权限主要分为4种:

  • private : 私有的, 同一个类中可以使用
  • (default) : 默认权限, 当不设定任何权限时,JVM会默认提供权限,包(路径)权限,子类的包不可以访问
  • protected : 受保护的权限, 子类可以访问
  • public : 公共的, 任意使用

所谓的访问权限,其实就是访问属性,方法的权力和限制。

public class Java17_Object_Access_1 {
    public static void main(String[] args) {

        // TODO 面向对象 - 访问权限
        Person17 person = new Person17();

        // private : 同类
        // default : 同类,同包(路径)
        // protected:同类,同包(路径),子类
        // public :公共的
        // 所谓的访问权限,其实就是访问属性,方法的权力和限制。
        // 谁访问?Java17_Object_Access_1 -> super -> java.lang.Object
        // 访问谁的?Person17 -> super -> java.lang.Object(clone)
//        person.clone();
    }

}
class Person17 {

    void test() throws Exception {
        clone();
    }
}

内部类:

  • Java不允许外部类使用private, protected修饰
    /所谓的外部类,就是在源码中直接声明的类
    所谓的内部类,就是类中声明的类

  • 内部类就当成外部类的属性使用即可

  • 因为内部类可以看作外部类的属性,所以需要构建外部类对象才可以使用

public class Java18_Object {
    public static void main(String[] args) {

        // TODO 面向对象 - 外部类 - 内部类
        // Java不允许外部类使用private, protected修饰
        // 所谓的外部类,就是在源码中直接声明的类
        // 所谓的内部类,就是类中声明的类

        // 内部类就当成外部类的属性使用即可

        // 因为内部类可以看作外部类的属性,所以需要构建外部类对象才可以使用
        OuterClass outer = new OuterClass();
        OuterClass.InnerClass innerClass = outer.new InnerClass();

    }


}
class OuterClass {
    public class InnerClass {

    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值