原文
void delegate() test(Object[] objs...) {
return {
foreach(obj; objs)assert(obj);
};
}
void delegate() foo() {
return test(new Object, new Object);
}
void main() {
auto ok = test(new Object, new Object);
ok(); // 没问题
auto it = foo(); // 其他地方构建
it(); // 触发失败.
}
猜测
是参数在闭包
栈上,所以ok()
调用很好,因为测试调用仍然存在.
但是,foo
调用把[newObject,newObject]
留在现在可能无效
的栈上.
此时,为闭包复制了其他局部变量
,但忽略了arg
可变参数.
@safe/dip1000
,未检测到.这是内存安全
问题.
简化版:
@safe
int delegate() test(scope int* p)
{
return () { return *p; };
}
p在动态分配
的闭包中,然后通过返回
的闭包逃逸
了.解决方法
是禁止把域变量
放入动态闭包
中.
且,如果在动态闭包
中引用变量
,则不能推断该变量
为域
.