假设我有以下函数:
foo <- function(x, y = min(m)) {
    m <- 1:10
    x + y
}当我运行foo(1)时,不出所料,返回值是2。但是,我不能运行foo(1, y = max(m))并接收11,因为惰性计算只对默认参数有效。我怎么能提供一个参数,但它的评估是懒惰的?
发布于 2009-11-04 12:52:19
简单的答案是,你不能也不应该尝试这样做。这打破了范围,如果允许的话,可能会造成严重破坏。有几个选项可以让你以不同的方式思考这个问题。
首先将y作为函数传递
foo<-function(x,y=min){
m<-1:10
x+y(m)
}如果一个简单的函数不起作用,你可以将m移到一个带有默认值的参数中。
foo<-function(x,y=min(m),m=1:10){
x+y(m)
}由于这只是一个玩具示例,因此我认为这太微不足道了。如果您坚持要打破作用域,那么您可以将其作为显式计算的表达式进行传递。
foo<-function(x,y=expression(min(m))){
m<-1:10
x+eval(y)
}然后可以选择从另一个函数返回一个函数。这可能也适用于你,这取决于你的目的。
bar<-function(f)function(x,y=f(m)){
m<-1:10
x+y
}
foo.min<-bar(min)
foo.min(1)  #2
foo.max<-bar(max)
foo.max(1)  #10但现在我们开始陷入荒唐的境地。
发布于 2009-09-08 17:30:25
我的解决方案是更改默认参数:
R> formals(foo)$y <- call("max", as.name("m"))
R> foo(1)
[1] 11发布于 2015-05-13 22:20:36
您可以使用substitute、eval组合。
foo <- function(x, y = min(m)) {
  y <- substitute(y)
  m <- 1:10
  x + eval(y)
}
foo(1)
## [1] 2
foo(1, y = max(m))
## [1] 11https://stackoverflow.com/questions/1395233
复制相似问题