我正在尝试将每个元素从一个ArrayList(av)复制到另一个(copia)。问题在于它们是通过引用复制的,因此每当我对原始版本进行任何更改时,副本也会被修改。当然,这种行为不是必需的。我该怎么写这个方法?
public void copiarArrayList(ArrayList<Articulo_Venta> copia, ArrayList<Articulo_Venta> av){
copia.clear();
for (int i = 0; i < av.size(); i++) {
copia.add(av.get(i));
}
}
Articulo_Venta有以下这些领域:
int codigo;
String nombre;
float cantidad;
PS:我也试过了下一个:
copia = new ArrayList<Articulo_Venta>(av);
但它的元素仍然指向原始的ArrayList。
答案 0 :(得分:8)
你想要的是深拷贝。如果您的对象只包含原语,则可以使用clone(),否则最好的方法是手动执行: -
在Articulo_Venta
类中创建一个构造函数,该构造函数接受另一个Articulo_Venta
对象并初始化成员变量。
然后将代码更改为: -
public void copiarArrayList(ArrayList<Articulo_Venta> copia, ArrayList<Articulo_Venta> av){
copia.clear();
for (int i = 0; i < av.size(); i++) {
copia.add(new Articulo_Venta(av.get(i)));
}
答案 1 :(得分:1)
在添加对象之前克隆它们。例如,而不是newList.addAll(oldList);
for(Articulo_Venta av : oldList) {
newList.add(av.clone());
}
克隆应该在Articulo_Venta中正确覆盖。
你就是这样做的。
public class Articulo_Venta {
String a; //assuming you have these fields, then
Date d;
...
public Articulo_Venta clone(){
Articulo_Venta av = new Articulo_Venta();
av.a = this.a.clone();
av.d = this.d.clone();
...
return av;
}
}
答案 2 :(得分:1)
在您的班级Articulo_Venta中创建一个新的构造函数。
public Articulo_Venta(int codigo, String number, float candidad)
{
this.codigo = codigo;
this.number = number;
this.candidad = candidad;
}
public void copiarArrayList(List<Articulo_Venta> copia, List<Articulo_Venta> av)
{
av.stream().forEach(t -> {
Articulo_Venta newObj = new Articulo_Venta(t.getCodigo(), t.getNumber(), t.getCandidad());
copia.add(newObj);
});
}