“最令人头痛的语法解析”(C++’s most vexing parse)

如果你传递了一个临时变量,而不是一个命名的变量;

C++编译器会将其解析为函数声明,而不是类型对象的定义。
例如:

std::thread my_thread(background_task());


这里相当与声明了一个名为my_thread的函数,这个函数带有一个参数(函数指针指向没有参数并返回background_task对象的函数),返回一个 std::thread 对象的函数,而非启动了一个线程;


写成下边这样可能更好理解一些:

class background_task
{
public:
    background_task operator()()
    {
        std::cout << "hello concurrency world!" << std::endl;
        return *this;
    }
    void doSomeWork() { std::cout << "hello do some work!" << std::endl; }
};

C++ std::thread my_thread(background_task (*)())
background_task a;
std::thread th(&background_task::doSomeWork, &a);

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章