我试图用‘outer_func_func’中的值覆盖变量a。我不希望它产生一个变量a外部的函数‘外层_func’。
inner_func <- function(){
a <<- 30
}
outer_func <- function(){
a <- 10
inner_func()
print(a)
}
outer_func()产量是10,但应该是30。
发布于 2018-10-04 13:12:23
这里有3种选择。(1)不改变inner_func,(3)不改变outer_func。
1)复制和重置inner_func环境,在outer_func中复制inner_func并强制当前环境复制到副本中。不对inner_func进行任何更改,只向outer_func添加一行,这两个行都会复制并更改其环境。
outer_func <- function() {
a <- 10
environment(inner_func) <- environment()
inner_func()
print(a)
}
outer_func()
## [1] 302)在outer_func中嵌套inner_func,另一种方法是在outer_func中嵌套inner_func。
outer_func <- function() {
inner_func <- function() {
a <<- 30
}
a <- 10
inner_func()
print(a)
}
outer_func()
## [1] 303)通过arg传递环境,另一种方法是通过参数将a所在的环境传递给inner_func。通过使父框架成为该参数的默认值,我们可以避免对outer_func进行任何更改。
inner_func <- function(envir = parent.frame()) {
envir$a <- 30
}
outer_func <- function() {
a <- 10
inner_func()
print(a)
}
outer_func()
## [1] 30备注
如果定义了a,比如在outer_func中定义了特定的矩阵元素,那么可以将其中的任何一个扩展到设置特定的矩阵元素。
a <- matrix(1:4, 2)在(1)和(2)中修改inner_func以便使用,例如:
a[1,1] <<- 30在(3)中使用,例如,在inner_func中
envir$a[1,1] <- 30https://stackoverflow.com/questions/52647202
复制相似问题