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.
The description is correct, the example is not.
copy-tree
would return the 1, 2 and 3 as is, copying only thecons
cells.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.
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):
So the hard cover book is correct.
Peter Seibel is reasonably assuming that numbers are stored directly in a cons cell rather than by reference: