为什么在PPL中不允许类成员变量为[& A,& B]

时间:2013-02-13 08:04:25

标签: c++ parallel-processing ppl

编译之前VS说

错误成员“test :: A”不是变量

错误成员“test :: B”不是变量

代码:

#include <iostream>
#include <ppl.h>

using namespace concurrency;
using namespace std;

class test
{
        static double A[ 3 ][ 3 ];
        static double B[ 3 ][ 3 ];
public:
        int test_function();
};

double test::A[ 3 ][ 3 ] = { {  0.7,  -0.2,   -1   },
                             { -4,    -2,     -2   },
                             { -0.4,   1.7,   -1.8 } };

double test::B[ 3 ][ 3 ] = { {  0.6,  -1.2,    1.1 },
                             {  2,     3,     -2   },
                             { -1,     0.05,   0.05} };

int test::test_function()
{
    parallel_for ( 0, 100, [ &A, &B ]( int y ) {
        for ( int x = 0; x < 100; x++ ) {

            for ( int i = 0; i < 3; i++ )
                for ( int j = 0; j < 3; j++ )
                     A[ j ][ i ] += A[ j ][ i ] * B[ j ][ i ];

        }
    } );
}

int main()
{
        return 0;
}

错误:

  

'test :: A':lambda捕获变量必须来自封闭的函数范围

     

'test :: B':lambda捕获变量必须来自封闭的函数范围

我该怎么办?

1 个答案:

答案 0 :(得分:2)

捕获静态毫无意义,因为它们是类静态。函数中定义的lambda具有与其定义的函数相同的可访问性。因此,在该函数中可见的变量(如类私有)在lambda中是可见的。

类静态成员仍然存在,即使该函数在其他地方传递或超过当前范围。

因此,只需在lambda中使用[]而不是[ <stuff> ]