My friends, for reprint please indicate the source: blog.csdn.net/jiangjunsho…
Disclaimer: During the teaching of artificial intelligence technology, many students asked me some python related questions, so in order to let students master more extended knowledge and better understand AI technology, I asked my assistant to share this Python series of tutorials, hoping to help you! Since this Python tutorial is not written by me, it is not as funny and boring as my AI teaching. But its knowledge points or say in place, also worth reading! PS: if you don’t understand this article, please read the previous article first. Step by step, you won’t feel difficult to learn a little every day!
As mentioned earlier, assignment stores references to objects, not copies of them. Because assignment results in multiple references to an object, modifying an object may affect other references to that object elsewhere in the program. If you don’t want to change everything, you need to explicitly tell Python to copy the object, rather than simply assign it.
For example, the following example creates a list X, and another list L, which nested references to list X. A dictionary D is also created with another reference to list X.
> > > X = [1, 2, 3] > > > L = [' a ', X, 'b'] # Embed references to X 's object > > > D = {' X: X,' y ': 2}Copy the code
In the above code, there are three references to the same object list: X, the second element of L, and the first element of D.
Since the list referenced by variable X is also referenced by L and D, and since lists are mutable, modifying any of the three list objects will also change the objects referenced by the other two.
>>> X[1] = 'surprise' # Changes all three references!
>>> L
['a',[1,'surprise',3],'b']
>>> D
{'x': [1,'surprise',3],'y': 2}
Copy the code
In most cases, this feature is to our advantage because you can pass large objects anywhere in the program without having to make copies en route, saving memory and increasing speed. However, if you don’t want this all-in-one feature, then you need to explicitly copy and copy.
• Unconstrained shard expressions (L[:]) can copy sequences. • The dictionary copy method (x.copy ()) copies dictionaries. • Some built-in functions (for example, list) can also generate copies (list (L)).
For example, if you have a list and a dictionary, you don’t want to change their values through other variable references.
>>> L = [1,2,3]
>>> D = {'a':1,'b':2}
Copy the code
Instead of making a reference copy, you can assign copies to other variables.
>>> A = L[:] # Instead of A = L (or list (L)) >>> B = d.c. opy () # Instead of B = D (ditto for sets)Copy the code
In this way, changes made by other variables only modify the copy, not the original object.
> > > A [1] = 'Ni' > > > B/' c '=' spam '> > > > > > L, D ([1, 2, 3]. {' A', 1, 'B' : 2}) > > > A, B ([1, "Ni", 3] and {' A ', 1, 'c' : 'spam', 'B' : 2})Copy the code
For the example at the beginning of this article, you can avoid references by sharding the original list.
> > > X = [1, 2, 3] > > > L = [' a ', X [:], 'b'] # Embed copies of X 's object > > > D = {' X: X [:],' y ': 2}Copy the code
L and D will now point to different lists instead of X. In this way, changes made through X can only affect X and not L and D. Similarly, changing L or D does not affect X.
Note that unconditional sharding and dictionary copy can only do top-level copy. That is, nested data structures cannot be copied. If you need to make a full copy of a deeply nested data structure, use the standard copy module — import copy and then execute X = copy.deepCopy (Y) to make a full copy of any nested object Y. This call statement can recursively traverse objects to copy all of their components.