The copy constructor creates dependent copy

前端 未结 5 1136
盖世英雄少女心
盖世英雄少女心 2021-01-23 16:34

I implemented the copy constructor as it is described here. But still the problem is that when I update route_copy, then the same update is applied to route

相关标签:
5条回答
  • 2021-01-23 17:12

    In your copy constructor, you are just doing a shallow copy, while you need to do a deep copy:

    public Route(Route r) {
        this(r.sites);
    }
    

    Here, you are still copying the reference of the list, which still points to the same ArrayList. You should modify it to create copy of list too. Possibly, you also need to create copy of the elements inside the arraylist like so:

    public Route(Route r) {
        List<Site> newSites = new ArrayList<Site>();
    
        for (Site obj: r.sites) {
            // Add copy of obj to the newSites
            // So you need yet another copy constructor in 'Site' class.
        }
    
        this.sites = newSites;
    }
    

    Check this post - Shallow Copy vs Deep Copy.

    0 讨论(0)
  • 2021-01-23 17:13

    what you do with the copy constructor is just make the new Route use the list of the old Route and therefor any change to one of them immediately effect the other

    what you need to do is make the copy constructor make a new list:

    sites = new ArrayList<Site>(oldList);
    
    0 讨论(0)
  • 2021-01-23 17:19

    Your "copy constructor" is not making a copy of the input list. Try something like

    public Route(List<Site> sites)
    {
        this.sites = new ArrayList<Site>(sites);
    }
    

    for your second constructor.

    0 讨论(0)
  • 2021-01-23 17:25

    The problem is that both lists are still pointing to the same memory location, thus, any operation on one list eventually modifies the other.

    You can try and use the copy constructor of the ArrayList:

    public ArrayList(Collection c)

    Constructs a list containing the elements of the specified collection, in the order they are returned by the collection's iterator.

    Like so:

         public Route(Route r) {
         this(new ArrayList<Site>(r.sites));
         }
    

    Note however that doing any modifications to the Site objects within the list might have repurcussions on the other objects stored in the other list, depending on how complex your Site object is.

    0 讨论(0)
  • 2021-01-23 17:36

    Ofcourse it'll create dependent copy also called Shallow copy.

    You need a Deep copy.

    0 讨论(0)
提交回复
热议问题