这个问题既不是这个问题的副本,也不是 这个问题的副本,它们是关于返回外部指针的函数。
这就是问题所在。此后的 Rcpp 代码定义了两个函数,一个创建 XPtr,另一个可以在 XPtr 上工作。
#include <Rcpp.h>
using namespace Rcpp;
//[[Rcpp::export]]
SEXP f(int n) {
std::vector<int> * v = new std::vector<int>;
for(int i = 0; i < n; i++)
v->push_back(i);
XPtr< std::vector<int> > p(v, true);
return p;
}
//[[Rcpp::export]]
int g(XPtr< std::vector<int> > p, int i) {
return (*p)[i];
它工作正常:
> x <- f(100)
> g(x, 45)
[1] 45
让我们尝试并行化对g
. 这有效:
require(parallel)
test1 <- function(a) {
cl <- makeForkCluster(nnodes=2)
r <- parLapply(cl, 1:5, function(i) g(a,i) )
stopCluster(cl)
return(r)
}
预期行为:
> unlist( test1(x) )
[1] 1 2 3 4 5
但这不起作用:
test2 <- function(a) {
cl <- makeForkCluster(nnodes=2)
p <- g(a, 0)
r <- parLapply(cl, 1:5, function(i) g(a,i) )
stopCluster(cl)
return(r)
}
意外行为:
> test2(x)
Error in checkForRemoteErrors(val) :
2 nodes produced errors; first error: external pointer is not valid
问题似乎是由于在调用集群中的从属设备之前在函数中使用了一次外部指针。什么解释了这种行为,是否有解决方法?提前谢谢了。