我有一个基类:
template <class T>
class A{
public:
// some data
T data;
//some functions like constructs etc.
...
// one virtual function
virtual void evaluate() = 0;
}
和派生类:
template <class T>
class B:public A<T>{
public:
// some functions like constructors etc.
virtual void evaluate();
__global__ void function2(); // **** error message
}
另外,我有
template <class T> void
B<T>::evaluate()
{
dim3 grid(1);dim3 block(1);
void function2<<<grid,block>>>();
}
和
template <class T> __global__ void B<T>::function2() // **** error message
{
// computation here
}
所以基本上我有一个派生类的成员函数,我希望在设备上以并行方式执行。
不幸的是,我收到错误:
error : illegal combination of memory qualifiers on the lines :
1> __global__ void function2(); // **** error message
2> template <class T> __global__ void B<T>::function2() // **** error message
我是CUDA的新手。如果有人指出我的错误,那将是非常友好的。我正在使用Visual Studio 2010进行开发。
答案 0 :(得分:3)
第一个代码段中的模板类定义是非法的,因为它包含__global__函数(CUDA内核)。根据{{3}},__ global__函数不能是静态类成员函数。出于同样的原因,第二个模板化的类成员函数是非法的。