gpt4 book ai didi

Java : when is a variable de-referenced

转载 作者:行者123 更新时间:2023-11-30 05:42:30 28 4
gpt4 key购买 nike

希望获得 Java 遵循的一些幕后内存引用和规则。

这是一段代码。基本上,此类用于实例化一些其他对象 (MyOtherObject),然后将此对象的 doClose() 方法的引用发送到 Vector。

如果创建 3 个 MyOtherObject 对象,则 Vector 将有 3 个条目。

最终将调用一个进程,导致监听器迭代 MyOtherObject 对象的 Vector,并为每个对象调用 doClose()。

目前代码显示

 myOtherObject = new myOtherObject();

作为 Activity 行。使用此行时,实际上只会关闭 3 个 MyOtherObject 对象中的 1 个。

如果代码改为

   MyOtherObject myOtherObject = new MyOtherObject();

然后 3 个 MyOtherObject 对象中的每一个都将调用其 doClose() 例程。

public class MyObject
{
MyOtherObject myOtherObject ;

public static MyObject getInstance()
{
:
:
:
return instance;
}

public void runThis ()
{

///MyOtherObject myOtherObject = new MyOtherObject(); //Works

myOtherObject = new myOtherObject(); //Only closes one

MyCustomObjectTracker customObjectTracker = new MyCustomObjectTracker()
{
@Override
public void closingMyWindows()
{
myOtherObject.doClose();
}
};

refernceToSomeOtherObject.addMyObjectTracker(customObjectTracker);
}
}

由于“工作”中的变量是本地变量,以后无法引用,因此当变量超出范围时,Java 是否会用实际对象引用替换该变量?

在只有 1 个被关闭的“不工作”场景中,这是因为该变量是一个实例变量,并且当引用 doClose() 对象时,它使用 myOtherObject 变量中恰好存在的引用doClose() 的执行时间?

基本上是寻找这些对象在幕后被取消引用的内容/时间以及是否有该行为的官方术语。

最佳答案

我不认为您的困惑与取消引用无关。我认为您的困惑在于闭包。当您像以前一样创建一个匿名类实例时,您正在创建一个闭包,它会执行一些神奇的调用堆栈操作来获取局部变量的当前状态。让我们首先看看您的工作示例。 (我删除了一些对此解释不必要的部分)

public class MyObject {
public void runThis() {
MyOtherObject myOtherObject = new MyOtherObject();
MyCustomObjectTracker customObjectTracker = new MyCustomObjectTracker() {
@Override
public void closingMyWindows() {
myOtherObject.doClose();
}
};
}
}

当您执行 new MyCustomObjectTracker() { ... } 时,Java 编译器会发现您使用了变量 myOtherObject,因此它会隐式围绕该变量关闭,记住稍后再说。请注意,这里重要的是,每次调用 runThis 时,您都会创建一个局部变量。它可能与旧变量具有相同的名称,但您创建了一个新的局部变量。因此,每个 customObjectTracker 都可以访问不同的局部变量。因此,一切顺利。现在,让我们看看您的另一个示例。

public class MyObject {
MyOtherObject myOtherObject;
public void runThis() {
myOtherObject = new MyOtherObject();
MyCustomObjectTracker customObjectTracker = new MyCustomObjectTracker() {
@Override
public void closingMyWindows() {
myOtherObject.doClose();
}
};
}
}

这里,代码遵循相同的原理。我们需要关闭名为 myOtherObject 的东西。但 myOtherObject 不是局部变量;它是一个局部变量。它是一个实例变量。所以实际上,我们需要关闭它所属的对象,即 this。请注意,只有一个 this。您可以多次调用runThis;你只在一个对象上调用它。因此,在本例中,您要多次更改一个变量,然后创建多个新类,所有类都指向该变量。

匿名类相对容易手动解构为“真实”类。因此,如果闭包让您感到困惑,请尝试将每个代码片段转换为不使用匿名类的形式(因此,不要使用 new MyCustomObjectTracker() { ... },而是创建一个新的文件(带有class MySpecialCustomObjectTracker extends MyCustomObjectTracker)。这样做会让您考虑必须将什么状态传递给新对象,这是编译器在创建匿名类实例时自动执行的操作。

关于Java : when is a variable de-referenced,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55405810/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com