cloneable接口实现原理,浅拷贝or深拷贝

实时快报 2024-10-23 02:41:28 842
导读 大家好,口实拷贝小芯来为大家解答以上的问题。cloneable接口实现原理,现原浅拷贝or深拷贝这个很多人还不知道,现在让我们一起来看看吧!1、理浅因为如果不继 大家好,深拷小芯来为大家解答以上的问题。cloneable接口实现原理,口实拷贝浅拷贝or深拷贝这个很多人还不知道,现在让我们一起来看看吧!1、现原因为如果不继承自Cloneable接口,理浅当调用clone()时会抛出CloneNotSupportedException异常以下是深拷详细讲解:   Java的所有类都默认继承java.lang.Object类,在java.lang.Object类中有一个方法clone()。口实拷贝2、现原JDK API的理浅说明文档解释这个方法将返回Object对象的一个拷贝。3、深拷要说明的口实拷贝有两点:一是拷贝对象返回的是一个新对象,而不是现原一个引用。4、理浅二是拷贝对象与用 new操作符返回的新对象的区别就是这个拷贝已经包含了一些原来对象的信息,而不是对象的初始信息。5、  怎样应用clone()方法?  一个很典型的调用clone()代码如下:class CloneClass implements Cloneable{ public int aInt; public Object clone(){  CloneClass o = null;  try{   o = (CloneClass)super.clone();  }catch(CloneNotSupportedException e){   e.printStackTrace();  }  return o; }}   有三个值得注意的地方,一是希望能实现clone功能的CloneClass类实现了Cloneable接口,这个接口属于java.lang 包,java.lang包已经被缺省的导入类中,所以不需要写成java.lang.Cloneable。6、另一个值得请注意的是重载了clone()方 法。7、最后在clone()方法中调用了super.clone(),这也意味着无论clone类的继承结构是什么样的,super.clone()直接或 间接调用了java.lang.Object类的clone()方法。8、下面再详细的解释一下这几点。9、  应该说第三点是最重要的,仔细 观察一下Object类的clone()一个native方法,native方法的效率一般来说都是远高于java中的非native方法。10、这也解释了为 什么要用Object中clone()方法而不是先new一个类,然后把原始对象中的信息赋到新对象中,虽然这也实现了clone功能。11、对于第二点,也要 观察Object类中的clone()还是一个protected属性的方法。12、这也意味着如果要应用clone()方法,必须继承Object类,在 Java中所有的类是缺省继承Object类的,也就不用关心这点了。13、然后重载clone()方法。14、还有一点要考虑的是为了让其它类能调用这个clone 类的clone()方法,重载之后要把clone()方法的属性设置为public。15、  那么clone类为什么还要实现 Cloneable接口呢?稍微注意一下,Cloneable接口是不包含任何方法的!其实这个接口仅仅是一个标志,而且这个标志也仅仅是针对 Object类中clone()方法的,如果clone类没有实现Cloneable接口,并调用了Object的clone()方法(也就是调用了 super.Clone()方法),那么Object的clone()方法就会抛出CloneNotSupportedException异常。16、因为clone声明的方法是接口所以实现接口的时候要全部实现接口所包含的全部方法这里的Cloneable接口就一个clone方法所以是这样..补充点public interface Cloneable此类实现了 Cloneable 接口,以指示 Object.clone() 方法可以合法地对该类实例进行按字段复制。17、 如果在没有实现 Cloneable 接口的实例上调用 Object 的 clone 方法,则会导致抛出 CloneNotSupportedException 异常。18、 按照惯例,实现此接口的类应该使用公共方法重写 Object.clone(它是受保护的)。19、请参阅 Object.clone(),以获得有关重写此方法的详细信息。20、 注意,此接口不 包含 clone 方法。21、因此,因为某个对象实现了此接口就克隆它是不可能的。22、即使 clone 方法是反射性调用的,也无法保证它将获得成功。23、 答案补充 是啊,这个时候实现的时候是根据用户自己去写里面的代码啊接口都是里面只有函数的声明,没有函数的实现所以这里的clone方法是用户自己去写的....... 答案补充 接口就是只有函数声明,没有函数实现;为什么要用这种,是因为在编写程序的时候一个类只能继承一个类,但是可以实现N个接口举个例子:interface yuyu{ public void tt() throw Exception;//这里定义为接口,就一定不能实现,实现会报错;//这个只有在后面使用的时候再实现它,使用接口的目的是为了代码的紧凑,//看起来比较直观....}public class demo implements yuyu{public void tt() throw Exception{//这里就要写代码进行具体实现!!!//这里可以实现N个接口,但是这里只是实现了yuyu,但是继承只能继承一个//还有这种的好处是,当很多类都要类似的方法的时候,//都可以实现这个yuyu接口,而很多的代码就可以不写了,大概就是这些原因吧...}} 答案补充 java中不是什么空接口,比如说序列化的接口Serializable这些具体含义以及作用(序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。24、可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。25、)都是由JDK作用标识好了的,如果你不实现这个接口你将自己去写自己的那一套处理对象流的机制的规范所以在这里就为java程序员提供了很大的好处(简便),不知道我上面说的,你能不能明白..只有实现这个接口才能完成你要的功能...java中要进行克隆的话clone必须实现的接口的原因如下:protected native Object clone() throws CloneNotSupportedException;该方法是 protected 的,显然是留待被子类 override 的。26、该方法又是 native 的,必然做了与具体平台相关的底层工作。27、事实上,类 Object 的 clone() 方法首先会检查 this.getClass() 是否实现了 Cloneable 接口。28、Cloneable 只是一个标志接口而已,用来标志该类是否有克隆功能。29、public interface Cloneable {}---------转载自网络-------1 Cloneable是标示接口与java.io.Serializable类似,用于告知JVM该对象实现clone。30、并且super.clone()可以返回一个复制。31、2 很多时候,会把protected的clone方法修改为public,暴露给其他人可以使用这是java很经典的标示接口,还有序列化接口也是什么方法也没有!它们的作用就是告诉虚拟机它们现在已经被标示了,可以进行相应的处理了!。本文到此分享完毕,希望对大家有所帮助。
本文地址:http://sgsrw.com/news/20241023/22a691313.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

友情链接