: = (передать по ссылке) в пакете data.table модифицирует другой объект таблицы данных одновременно

При тестировании моего кода я выяснил следующее: если я присвою data.table DT1 - DT и изменим DT после этого, DT1 изменится вместе с ним. Таким образом, DT и DT1 кажутся внутренне связанными. Это намеренное поведение? Хотя я не специалист по программированию, это выглядит неправильно для меня, и, тестируя его с помощью простых R-переменных или data.frame, я не мог воспроизвести поведение. Что здесь происходит?

DF <- data.frame(ID=letters[1:5],
                  value=1:5)
DF1 <- DF
all.equal(DF1, DF)
[1] TRUE
DF[1, "value"] <- DF[1, "value"]*2
all.equal(DF1, DF)
[1] "Component 2: Mean relative difference: 1"

library(data.table)
data.table 1.7.1  For help type: help("data.table")
DT <- data.table(ID=letters[1:5],
                  value=1:5)
DT1 <- DT
all.equal(DT1, DT)
[1] TRUE
DT[, value:=value*2]
     ID value
[1,]  a     2
[2,]  b     4
[3,]  c     6
[4,]  d     8
[5,]  e    10
all.equal(DT1, DT)
[1] TRUE

Ответ 1

Эта документация в data.table поможет. ? data.table::copy

Не возвращается значение. Таблица данных модифицируется ссылкой. Если вам нужна копия, сначала сделайте копию (используя DT2 = copy (DT)). copy() также иногда может быть полезен до: = используется для переназначения столбца по ссылке.