在if语句中声明类变量

gal*_*tte 3 c++ variables if-statement class

c ++接受:

if(int a=1)
{
    //...
}
Run Code Online (Sandbox Code Playgroud)

出于学习目的,我编写了一个简单的锁机制类:

class SimpleLock
{
public:
    class Token
    {
    public:
        friend class SimpleLock;
        Token(SimpleLock & lock) : lock(lock), locked(!lock.locked.exchange(true)) { }
        ~Token() { if(locked) lock.locked.store(false); }
        operator bool() const { return locked; }

    private:
        SimpleLock & lock;
        const bool locked;
    };

    SimpleLock() : locked(false) { }

private:
    std::atomic_bool locked;
};
Run Code Online (Sandbox Code Playgroud)

允许我这样做:

SimpleLock::Token t(lock);

if(t) //Token has an operator bool() overload
{
    //...
}
Run Code Online (Sandbox Code Playgroud)

以下为什么不编译?

if(SimpleLock::Token t(lock))
{
    //...
}
Run Code Online (Sandbox Code Playgroud)

编译错误:

在't'之前预期的初级表达

在线代码链接:http://goo.gl/Knrmw7

Tar*_*ama 10

它不会编译,因为在if条件中不允许这种形式的初始化.这仅仅是标准所说的有效的句法形式.

您可以使用复制初始化表单或braced-init-list:

if(SimpleLock::Token t = SimpleLock::Token(lock))
{
    //...
}

if(SimpleLock::Token t{lock})
{
    //...
}
Run Code Online (Sandbox Code Playgroud)

这在[stmt.select]/1(N3337)中规定:

条件:

  • 表达

  • attribute-specifier-seq opt decl-specifier-seq declarator = initializer-clause

  • attribute-specifier-seq opt decl-specifier-seq declarator braced-init-list