请,任何人都可以解释一下,在这种情况下如何存储conditionalVariable,以便在check_calls_on_current_floor在条件块之外调用时使用?
std::function<bool()> check_calls_on_current_floor;
if (/*Some condition*/)
{
const int conditionalVariable = /*some value*/;
check_calls_on_current_floor = [&](){
return conditionalVariable == 10; };
}
check_calls_on_current_floor();
在这种情况下,我们可以在条件块之外访问这个变量,以防我们从那里得到lambda。
答案 0 :(得分:3)
这是一个悬垂的参考。在if
块之后进行该调用是未定义的行为。它与从函数返回对局部变量的引用非常相似。它甚至更类似于:
struct ref_holder
{
ref_holder(const int & r) :ref(r) {}
const int & ref;
};
int main()
{
std::unique_ptr<ref_holder> ptr;
if (true)
{
const int conditionalVariable = 10;
ptr.reset(new ref_holder(conditionalVariable));
}
ptr->ref == 10; // undefined behavior
}
答案 1 :(得分:1)
这有点类似于:
int x = 0;
int* z = &x;
if (condition)
{
int y = 1;
z = &y;
}
如果条件成立,则z
将指向已超出范围的y
。
答案 2 :(得分:1)
这个条件变量超出了它的范围但在范围内。
我认为这会对你有所帮助。 http://en.wikipedia.org/wiki/Variable_(computer_science)#Scope_and_extent