为什么我们在Java中使用clone()方法?
为什么我们clone()
在Java中使用该方法?(请给出有关内存限制的答案。)这会减少内存使用吗?如果是,那怎么办?这样会减少内存泄漏的影响吗?
回答:
除了 不使用克隆外,还实现一个复制构造函数 ,您询问了内存限制。
克隆 的想法是创建克隆对象的精确副本。因此,在最坏的情况下,此后您将使用两倍的内存量。实际上-
少了一点,因为String经常被嵌入并且(通常)不会被克隆。即使由clone方法/ copy构造函数的实现者来决定。
这是带有复制构造函数的类的简短示例:
public class Sheep { private String name;
private Fur fur;
private Eye[2] eyes;
//...
// the copy constructor
public Sheep(Sheep sheep) {
// String already has a copy constructor ;)
this.name = new String(sheep.name);
// assuming Fur and Eye have copy constructors, necessary for proper cloning
this.fur = new Fur(sheep.fur);
this.eyes = new Eye[2];
for (int i = 0; i < 2; i++)
eyes[i] = new Eye(sheep.eyes[i]);
}
}
用法:
Sheep dolly = getDolly(); // some magic to get a sheepSheep dollyClone = new Sheep(dolly);
以上是 为什么我们在Java中使用clone()方法? 的全部内容, 来源链接: utcz.com/qa/420603.html