我想以灵活的方式指定功能。当我在其后创建另一个函数时,如何确保给定函数的环境不会改变。
为了说明,这可以正常工作:
make.fn2 <- function(a, b) {
fn2 <- function(x) {
return( x + a + b )
}
return( fn2 )
}
a <- 2; b <- 3
fn2.1 <- make.fn2(a, b)
fn2.1(3) # 8
fn2.1(4) # 9
a <- 4
fn2.2 <- make.fn2(a, b)
fn2.2(3) # 10
fn2.1(3) # 8
这不是
make.fn2 <- function(a, b) {
fn2 <- function(x) {
return( x + a + b )
}
return( fn2 )
}
a <- 2; b <- 3
fn2.1 <- make.fn2(a, b)
a <- 4
fn2.2 <- make.fn2(a, b)
fn2.1(3) # 10
fn2.1(4) # 11
fn2.2(3) # 10
fn2.1(3) # 10
答案 0 :(得分:8)
这是由于懒惰的评估。在调用函数之前,该函数实际上并未构造。因此,在第二种情况下,两次都会选择a
的新版本。另请参阅this other question。
您可以使用force
:
make.fn2 <- function(a, b) {
force(a)
force(b)
fn2 <- function(x) {
return( x + a + b )
}
return( fn2 )
}
这会强制函数在创建函数时获取a
和b
的值,而不是在调用函数时。它产生正确的输出:
> a <- 2; b <- 3
> fn2.1 <- make.fn2(a, b)
>
> a <- 4
> fn2.2 <- make.fn2(a, b)
>
> fn2.1(3) # 10
[1] 8
> fn2.1(4) # 11
[1] 9
> fn2.2(3) # 10
[1] 10
> fn2.1(3) # 10
[1] 8
>