gpt4 book ai didi

java - 将 this(在构造函数中)泄漏给对象本身

转载 作者:塔克拉玛干 更新时间:2023-11-01 22:08:28 25 4
gpt4 key购买 nike

我从 SO 的其他问题中了解到,如果另一个对象有机会利用仍在构造中的对象(我们泄漏的对象),那么泄漏 this 是如何不安全的,两者都是单一的-线程和多线程环境。

我的问题是,如果我将对象泄露给它自己怎么办?

public Category(int id, String name) {
this.id = id;
this.name = name;
this.idPadre = this;
}

请注意,在构造函数的最后一行中,我正在泄漏对象。这通常仍然是不安全的,因为构造函数可以被继承并与 super() 调用一起使用,在执行父类的构造函数(我写的这个)之后使用更多代码,从而使泄漏线不是施工过程的最后一行。

但是,如果继承类仍在其构造函数中,那么即使它正在泄漏正在构造的对象并且泄漏线后面有更多代码行,考虑到唯一可以访问的上下文,它仍然是不安全的吗泄漏的对象是该对象的构造函数(仍未完成执行)?

问题也代表多线程环境。我很确定它是线程安全的,因为对象正在泄漏给自身(它的字段之一)并且在构造函数完成之前无法访问这些字段。根据能够访问泄漏对象的构造函数,构造函数仅在一个线程中运行,因此它应该是线程安全的(如果它在这个问题的第一部分所指的方面也是安全的)。

我想笼统地问这个问题。但这是我发现这种情况的背景。该类是一个实体类,我使用 ORMLite 将其保存到关系数据库中。数据库表有一列,其值指向该条目类别的父级。如果 Category 没有父级,它本身就是它的父级(列 idPadre 的值与列 id 的值相同)。当使用 ORMLite 的注释编写实体类时,这意味着该对象具有对自身的引用。 ORMLite 的使用和我希望让所有实体类尽可能简单的愿望是我不首先倾向于使用工厂方法解决这个问题的原因。

最佳答案

当您将 this 分配给字段 idPadre 时,只有在您已经拥有对该对象的引用才能访问该字段时,才能访问该对象。换句话说,您没有泄露构造函数调用者尚未泄露的任何内容,可以这么说。

泄漏 this 通常意味着在构造函数完成之前从构造函数泄漏对对象的引用。从构造函数中泄漏 this 的问题是字段可能没有正确初始化。在这种情况下,这不是问题,因为您只能在构造函数完成后访问 idPadre(除非您已经在构造函数中早些时候泄漏了 this - 但是您已经泄漏了 这个!)

如果 idPadre 是一个静态字段那么这确实会泄漏 this 因为其他线程可以随时访问静态字段。

关于java - 将 this(在构造函数中)泄漏给对象本身,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31259261/

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