您的位置:首页 > 编程语言 > C语言/C++

《C++ concurrency in action》第二章解析

2014-10-25 08:46 316 查看


如图,书中写到有件事情需要考虑到的是:当传一个函数对象给一个线程的构造函数的时候,需要小心c++复杂的解析,如果您如下传一个临时变量而不是一个左值的时候,

语法形式便和一个函数的申明是一样的。介于国内并无此教材,所以有些人看到这里会感到困惑,我作如下解释:

我们会从最基本的开始。这行声明了一个函数带有double而且返回int

int foo(double d);

第二行做了同样的事情,名为d的参数左右的括号是多余的,被忽略:

int foo(double (d));

下面这行声明了同样的函数,它只是省略了参数名:

int foo(double);

让我们再看看三个函数的声明,第一个声明了一个函数g,它带有一个参数,那个参数是指向一个没有参数,返回double的函数指针:

int g(double (*p)());

这是完成同一件事的另一种方式,唯一不同的是p使用非函数指针语法来声明:

int g(double p());

照常,参数名可以省略,所以这是g的第三种声明:

int g(double());

注意参数名左右的括号(就像是第二种声明中的)和单独的括号(一如本例)之间的区别,参数名左右的括号被忽略,但单独的括号之处存在一个参数列表,他们生命了存在指向函数的指针的参数。

用这些foo 和 g的声明做了热身,我们准备解读本文中的代码:



所以参数里面被解析成一个函数指针且类型为指向参数为空返回值为background_task的函数指针

by Chan J. Lee QQ:1355425625欢迎技术交流
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: