到目前为止我的研究
大多数文章都讨论了 和 之间的区别class
,但我对、和之间的区别并typeof
没有发现太多。mode
storage.mode
typeof
我明白了mode
,storage.mode
和typeof
更相似,class
也更不同。我知道前两个电话typeof
,我知道他们处理特定类型略有不同(我什至知道哪些以及如何处理)。我想知道的是这背后的想法是什么。
最小的工作示例
library(data.table)
my_vector_boolean <- c(TRUE, FALSE, T, F)
my_vector_integer <- c(1L, 2L, 3L)
my_vector_character <- c("a", "b", "abc")
my_vector_factor <- as.factor(c("a", "b", "c"))
my_list <- list(a=1, b=2L, c="c")
my_matrix <- matrix(c(1,2,3, 11,12,13), nrow = 2, ncol = 3, byrow = TRUE,
dimnames = list(c("row1", "row2"), c("col1", "col2", "col3")))
my_dataframe <- data.frame(1, 1L:10L, sample(3, 10, replace = TRUE))
my_datatable <- data.table(1, 1L:10L, sample(3, 10, replace = TRUE))
datatypeslist <- list(
my_vector_boolean = my_vector_boolean,
my_vector_integer = my_vector_integer,
my_vector_character = my_vector_character,
my_vector_factor = my_vector_factor,
my_list = my_list,
my_matrix = my_matrix,
my_dataframe = my_dataframe,
my_datatable = my_datatable
)
multi.sapply <- function(...) {
arglist <- match.call(expand.dots = FALSE)$...
var.names <- sapply(arglist, deparse)
has.name <- (names(arglist) != "")
var.names[has.name] <- names(arglist)[has.name]
arglist <- lapply(arglist, eval.parent, n = 2)
x <- arglist[[1]]
arglist[[1]] <- NULL
result <- sapply(arglist, function (FUN, x) sapply(x, FUN), x)
colnames(result) <- var.names[-1]
return(result)
}
multi.sapply(datatypeslist, typeof, storage.mode, mode, class)
我在找什么
我不是在寻找什么样的答案:“mode
并以不同的方式storage.mode
处理single
。
我正在寻找什么样的答案:“typeof
是在底层 C 实现中使用的mode
数据类型,而是......的数据类型并且storage.mode
是......的数据类型”
此外,我希望能够区分手册和教程中使用的术语“模式”和“类型”。例如,有人说typeof
返回数据对象的模式——这让我感到困惑。
我希望这个问题足够具体/清楚。在否决或投票结束之前,请告诉我有什么不清楚的地方。