面向对象的继承方式(汇总)

第一种: 原型链的方式

       function Parent(name){
            this.name=name;
        }
        Parent.prototype.say=function(){
            console.log('saying');
        }
        function Child(name,age){
            this.name = name;
            this.age=age;
        }
        Child.prototype = new Parent();
        Child.prototype.constructor=Child;//修复
        var c1=  new Child('Tom',18);
        console.log(c1);
        console.log(c1.name,c1.age);
        console.log(Child.prototype.constructor);

第二种: 借用构造函数

        function Parent(name) {
            this.name =name;
        }

        function Child(name,age) {
            Parent.call(this);
            this.age = age;
        }

        var c1=  new Child('Tom',18);
        console.log(c1.name,c1.age);

第三种: 组合继承

       function Parent(name) {
            this.name = name;
            this.walk=function(){
                console.log('waking~~~');
            }
        }
        Parent.prototype.say = function () {
            console.log('saying~~~');
        }
        function Child(name, age) {
            Parent.call(this,name,age);
            this.age = age;
        }
        Child.prototype = new Parent();
        Child.prototype.constructor = Child;//修复
        var c1 = new Child('Tom', 18);
        console.log(c1.name, c1.age);
        c1.say()

第四种: 寄生式组合继承   ----最完美的继承的方法

       function Parent(name) {
            this.name = name;
            this.walk = function () {
                console.log('waking~~~');
            }
        }
        Parent.prototype.say = function () {
            console.log('saying~~~');
        }
        function Child(name, age) {
            Parent.call(this, name, age);
            this.age = age;
        }
        Child.prototype = Object.create(Child.prototype);
        Child.prototype.constructor = Child;//修复
        //在这里增加新方法
        var c1 = new Child('Tom', 18);
        console.log(c1.name, c1.age);
        c1.say()

第五种: 寄生式继承  ---了解即可

        function createAnother(original) {
            var clone = Object.create(original);    //通过调用函数创建一个新对象
            clone.sayHi = function () {               //以某种方式来增强这个对象
                alert("Hi");
            };

            return clone;                        //返回这个对象
        }
        
        var person = {
            name: "Bob",
            friends: ["Shelby", "Court", "Van"]
        };
        var anotherPerson = createAnother(person);
        anotherPerson.sayHi();
       // anotherPerson是基于person创建的一个新对象,新对象不仅具有person的所有属性和方法,还有自己的sayHi()方法。
  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中级面试中,通常会涉及以下几个方面的问题: 1. 面向对象概念:Java是一种面向对象的编程语言,因此面试官可能会问到面向对象的基本概念,如封装、继承和多态等。 2. 类和对象:面试官可能会问到如何定义类和对象,以及它们之间的关系。你需要了解如何创建类的实例,并对类的成员变量和方法进行调用。 3. 继承与接口:Java中的继承和接口是面向对象编程的重要组成部分。你需要理解继承的概念和实现方式,并能够解释为什么接口对于Java程序的设计很重要。 4. 异常处理:了解Java异常处理机制是很重要的。你需要熟悉checked和unchecked异常的区别,并能够正确处理异常情况。 5. 多线程:Java具有多线程支持,因此你需要了解如何创建和管理线程,以及线程之间的同步与互斥。 6. 集合类:Java提供了丰富的集合类库,包括ArrayList、LinkedList、HashMap等。你需要了解各种集合类的特点和使用方式。 7. IO操作:Java的IO操作常常在面试中被问到。你需要熟悉如何使用InputStream、OutputStream、Reader和Writer等类进行输入输出操作。 8. JDBC和数据库:了解Java数据库连接(JDBC)的基本概念和使用方式,以及如何通过Java程序连接和操作数据库。 在面试过程中,除了以上方面的问题,还可能涉及其他具体的Java特性和技术,如反射、注解、单元测试等。因此,为了在面试中表现出色,你需要准备全面、扎实的Java基础知识,并能够灵活运用它们来解决实际编程问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值