博客
关于我
多态中变量和方法的一些思考
阅读量:494 次
发布时间:2019-03-07

本文共 774 字,大约阅读时间需要 2 分钟。

多态在Java中允许同一个变量引用不同类的对象,但变量的类型是固定的,无法重写。方法则可以根据运行时的类来执行不同的逻辑,这是多态的关键点。以下是详细的解释:

  • 变量与多态

    • 变量的类型在声明时确定,无法改变。例如,父类和子类都有相同的变量arm_length,但当创建一个子类实例并赋值给父类变量时,变量的值始终指向父类的值。这是因为变量是基于其声明的类型来获取值的,而不是运行时的对象类型。
    • 因此,父类引用调用的是父类的变量值,而不是子类的。
  • 方法与多态

    • 方法可以重写,因为它们是基于运行时对象的类型来执行的。当子类覆盖了父类的方法时,父类引用会调用子类的方法,这样可以实现不同的行为。
    • 在代码中,father.buyTobacco()调用的是子类重写的方法,因为运行时的对象是Son实例。
  • 多态的意义

    • 变量和方法的区别体现了多态的两个方面:变量是属性,方法是行为。变量的多态性(即继承)不涉及重写,而方法的多态性涉及行为的不同实现。
    • 这种设计使得代码更灵活,符合面向接口的设计原则,允许同一接口有多个实现。
  • 示例分析

    • 父类Father的arm_length是60,子类Son的arm_length是65。当创建Father father = new Son();时,father.arm_length输出60,因为变量是根据父类类型来获取值。
    • father.buyTobacco()输出“儿子爱抽黄鹤楼”,因为方法是根据运行时的对象类型来调用的。
  • 总结

    • 变量的类型决定了其值,无法通过重写来改变。
    • 方法的重写允许不同的对象在相同的接口下执行不同的行为。
    • 这种设计保持了代码的清晰性和可维护性,符合多态的原则。
  • 通过以上分析,可以看出变量和方法在多态中的不同处理方式,变量基于声明类型,而方法基于运行时对象类型,这样实现了灵活的行为多态。

    转载地址:http://bxwcz.baihongyu.com/

    你可能感兴趣的文章
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm如何清空缓存并重新打包?
    查看>>
    npm学习(十一)之package-lock.json
    查看>>
    npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
    查看>>
    npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
    查看>>
    npm安装教程
    查看>>
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>
    npm报错Failed at the node-sass@4.14.1 postinstall script
    查看>>
    npm报错fatal: Could not read from remote repository
    查看>>
    npm报错File to import not found or unreadable: @/assets/styles/global.scss.
    查看>>
    npm报错TypeError: this.getOptions is not a function
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
    查看>>
    npm版本过高问题
    查看>>
    npm的“--force“和“--legacy-peer-deps“参数
    查看>>
    npm的安装和更新---npm工作笔记002
    查看>>
    npm的常用操作---npm工作笔记003
    查看>>
    npm的常用配置项---npm工作笔记004
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>