【发布时间】:2013-07-06 08:03:19
【问题描述】:
我有一个基类:
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 上开发。
【问题讨论】:
-
__global__函数不能是 CUDA 中的类静态成员。 -
这是@talonmies 评论的documentation reference。
-
我的评论不会为 talonmies 和 Robert Crovella 已经向您指出的内容添加任何新内容。您真的需要将
function2定义为静态成员函数吗?我还在 Visual Studio 2010 下使用带有 CUDA 的模板类,并将我的所有__global__函数定义为非成员函数。 -
@talonmies 我认为这足以作为答案。如果您将其发布为答案,我会赞成。
-
最后评论。我想说您的问题与该类是否派生无关。是否可以跳过您帖子的此详细信息?
标签: c++ visual-studio-2010 cuda