Common Lisp's copy-tree: Which objects will be referenced in common by the original and the copy?

StackOverflow https://stackoverflow.com//questions/12716371

  •  13-12-2019
  •  | 
  •  

Question

I'm reading Practical Common Lisp, and have a question about Lisp's COPY-TREE function.

The book gives the example of calling

(copy-tree '( '(1 2) '(3 4) '(5 6)))

After explaining it, the book makes this statement:

Where a cons cell in the original referenced an atomic value, the corresponding cons cell in the copy will reference the same value. Thus, the only objects referenced in common by the original tree and the copy produced by COPY-TREE are the numbers 5, 6, and the symbol NIL.

But that doesn't make sense to me. I thought all atoms would be shared between the original and the new. Therefore, I expected that 1, 2, 3, 4, 5, 6 and NIL would all be shared between the original and the copy, and that the only "new objects" would be all the CONS cells.

Which one is correct, and why?

Thanks.

Was it helpful?

Solution

I check the web-version, a pdf version and the hard cover. The first two are wrong as you state. The hard cover states this (bold emphasis is mine):

Where a cons cell in the original referenced an atomic value, the corresponding cons cell in the copy will reference the same value. Thus, the only objects referenced in common by the original tree and the copy produced by COPY-TREE are the numbers 1-6, and the symbol NIL.

So the hard cover book is correct.

OTHER TIPS

It is slightly more complicated.

The cons cells will be copied. Typically the objects the cons cells references will not be copied.

But there is one exception. Data like fixnums and characters can be stored inline in cons cells (and structure slots, class slots, arrays). Such data types are not necessarily EQ. That's why there is EQL.

The description is correct, the example is not. copy-tree would return the 1, 2 and 3 as is, copying only the cons cells.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top