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

为什么#clone()不在Cloneable接口中?

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

为什么#clone()不在Cloneable接口中?

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


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

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

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