我正在阅读有关如何正确执行数组深拷贝的信息,但是我对如何#clone()
实现数组感到困惑。它是java.lang.Object
该类的成员,但是,如果您阅读javadocs:
首先,如果此对象的类未实现Cloneable接口,则将引发CloneNotSupportedException。
那么为什么要首先定义clone
方法呢?当然,如果仅当存在接口时才可以使用方法,则可以将方法放在接口中。该Cloneable
接口本身是空的;
它只是Java用来确保使用该clone
方法合法的标记接口。
以这种方式执行操作还消除了使用泛型来确保类型安全的能力:
class Foo implements Cloneable { // Valid.
@Override
public Object clone() throws CloneNotSupportedException {
// ...
}
}
class TypeSafeFoo implements Cloneable<TypeSafeFoo> { // Not valid.
@Override
public TypeSafeFoo clone() throws CloneNotSupportedException {
// ...
}
}
Java为什么要这样做?我敢肯定他们有正当的理由,但我似乎无法弄清楚。
Java中的克隆协定规定,每个clone
实现都必须首先从中获取克隆的实例super.clone()
。这将创建一条始终以对的调用结尾的链Object.clone
,并且该方法包含“神奇的”本机级代码,该代码对struct
表示Java对象的基础原始文件进行二进制复制。如果不存在该机制,clone
则将不会是多态的:该Object.clone
方法将生成所调用的任何类的实例;如果没有本地代码,则无法复制。
这就是为什么Object.clone
无法避免该方法的原因。Cloneable
本可以
包含一个clone
方法,但是会产生有关该throws
子句的问题。按照这种方式,您可以自由声明clone
没有声明的异常,也可以声明任意的异常。如果该方法已经在接口中声明,则这种灵活性将是不可能的。
请记住,泛型对于克隆几乎没有用:想象protected T clone()
在Object
:哪里会T
来?我们是否需要Object<T>
并强迫
Java Universe中的每个类都 对其自身进行参数化,而所有这些仅仅是为了使这种半不推荐使用的机制工作得更好一点?还请记住,此代码完全合法:
public class TheMightyOne implements Cloneable {
@Override public TheMightyOne clone() {
return (TheMightyOne) super.clone();
}
}
您可以称之为:
TheMightyOne one = new TheMightyOne();
TheMightyOne two = one.clone(); // do downcasts needed
我正在阅读如何正确执行数组的深度复制,但是我对是如何实现的感到困惑。它是类的成员,但是如果您阅读Javadocs: 首先,如果该对象的类没有实现接口Cloneable,则抛出CloneNotSupportedException。 为什么Java要这样做?我肯定他们有正当的理由,但我似乎想不通。
我试图理解object.clone()在Java中是如何工作的。我偶然发现了以下事实: null 疑点: 为什么Java设计者会做出这样的设计选择并这样实现它?为什么不在本身中定义,如果实现类不为提供实现,那么将产生编译时错误。 Q2.为什么要在运行时检查实例是否实现? 附:我知道在一个问题中问多个问题是一个坏主意。但这些都是密切相关的问题。我可以问一个问题,比如“为什么不包含?”但是,我觉得,为
问题内容: Java固有地被破坏了。具体来说,我与接口有关的最大问题是,它期望方法行为无法定义方法本身。因此,如果遍历列表,则必须使用反射来访问其定义的行为。但是,在Java 8中,我们现在有了默认方法,现在我问为什么在中没有默认方法。 我知道为什么接口不能使用默认的Object方法,但是,这是一个明确的设计决定,因此可以进行例外处理。 我有点设想过时,并将其内部代码更改为以下内容: 并且继续进行
问题内容: 众所周知,Java 中的接口已损坏。造成这种情况的原因很多,我将不再赘述。其他人已经做到了。这也是Java架构师本身的立场。 因此,我的问题是:为什么还不被弃用?如果核心Java团队已确定它已损坏,那么他们还必须考虑过时。他们反对这样做的原因是什么(在Java 8中仍不建议弃用)? 问题答案: 有一个错误在1997年提交给Java的错误数据库有关添加方法,所以将不再是无用的。它以“无法
本文向大家介绍请解释为什么集合类没有实现Cloneable和Serializable接口?相关面试题,主要包含被问及请解释为什么集合类没有实现Cloneable和Serializable接口?时的应答技巧和注意事项,需要的朋友参考一下 考察点:JAVA集合 克隆(cloning)或者是序列化(serialization)的语义和含义是跟具体的实现相关的。因此,应该由集合类的具体实现来决定如何被克隆
问题内容: 看来,许多人已经开始用组合代替。这似乎很愚蠢,不幸的是,像Jenkins这样的工具无法为您做到这一点。那么,为什么git clone不采用refspec,就像git fetch一样? 具体来说,如果您希望在Jenkins上运行gerrit触发的构建任务,则需要确保工作空间存在,否则jenkins将无法检出包含gerrit更改的修订。这是因为gerrit使用的引用路径不在git克隆获取的