栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

实例变量初始化中的问题

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

实例变量初始化中的问题

首先,由于缺乏

someLookup
方法,该代码无法编译。

无论如何,我相信您的问题是,由于构造函数是分层运行的,您的期望是无效的。

超类的构造函数始终在子类的构造函数之前运行,这包括子类的变量的初始化程序(实际上是作为构造函数的一部分运行)。因此,当您创建的实例时

Derived
,会发生以下情况:

  1. base
    构造函数首先被调用。
  2. lookup()
    被调用,它使用中的实现
    Derived
  3. num
    返回 这是默认值,因为尚未运行Derived的构造函数和初始化程序
  4. val
    设置为0。
  5. Derived
    初始化和构造都运行-呼吁
    lookup
    这个 点上会返回10。

通常,正是出于这个原因,从构造函数中调用非最终方法是一个坏主意,许多静态分析工具都会警告您。这类似于在构造过程中让对象引用泄漏,您可以得到一个实例,该实例使类级不变式失效(在您的情况下,Derived的

num
“总是”为10,但在某些情况下可以看到为0)。

编辑:请注意,对于这种 特殊 情况,无需任何其他代码,您可以通过使

num
常量来解决问题:

class Derived extends base{  private static final int num = 10;  ...

这实际上会做您想要的事情,因为静态初始化程序是在加载类时运行的(必须在调用构造函数之前发生)。但是,这确实假定适用于:

a)该类的所有实例共享相同的

num
变量;b)
num
无需更改(如果为true,则(a)自动为true)。

在给出的确切代码中,显然是这样,但是我希望您可能为了简洁而省略了额外的功能。

我将其包括在这里是出于比较和关注的目的,不是因为从一般意义上说,这是针对该“问题”的解决方法(因为不是这样)。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/496968.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号