如没有区别,还要clone方法干什么?
还有如何控制clone只复制部分属性值?
------解决方案--------------------
protected Object clone()
throws CloneNotSupportedException创建并返回此对象的一个副本。“副本”的准确含义可能依赖于对象的类。一般来说,对于任何对象 x,如果表达式:
x.clone() != x是正确的,则表达式:
x.clone().getClass() == x.getClass()将为 true,但这些不是绝对条件。一般情况下是:
x.clone().equals(x)将为 true,但这不是绝对条件。
按照惯例,返回的对象应该通过调用 super.clone 获得。如果一个类及其所有的超类(Object 除外)都遵守此约定,则 x.clone().getClass() == x.getClass()。
按照惯例,此方法返回的对象应该独立于该对象(正被克隆的对象)。要获得此独立性,在 super.clone 返回对象之前,有必要对该对象的一个或多个字段进行修改。这通常意味着要复制包含正在被克隆对象的内部“深层结构”的所有可变对象,并使用对副本的引用替换对这些对象的引用。如果一个类只包含基本字段或对不变对象的引用,那么通常不需要修改 super.clone 返回的对象中的字段。
Object 类的 clone 方法执行特定的克隆操作。首先,如果此对象的类不能实现接口 Cloneable,则会抛出 CloneNotSupportedException。注意:所有的数组都被视为实现接口 Cloneable。否则,此方法会创建此对象的类的一个新实例,并像通过分配那样,严格使用此对象相应字段的内容初始化该对象的所有字段;这些字段的内容没有被自我克隆。所以,此方法执行的是该对象的“浅表复制”,而不“深层复制”操作。
Object 类本身不实现接口 Cloneable,所以在类为 Object 的对象上调用 clone 方法将会导致在运行时抛出异常。
------解决方案--------------------
有些属性你未必 get 得到。所以使用 clone() 方法更加合理一些。
------解决方案--------------------
clone方法是浅复制,浅一点的理解就是 一个对象的引用!
------解决方案--------------------
> > 那如何控制clone只复制部分属性值?
重写 clone() 方法。
------解决方案--------------------
好像没啥区别,不过至少你要是用到的地方都构造函数get set恐怕是相当大的工作量,而且private的冬冬类外面恐怕不是那么容易拿到的吧
重写。。。。。。。。。。。。。跟重写别的函数是一样的阿,在clone函数里面写上你要实现的功能