将指向模板类对象的指针正确传递给函数
Passing pointer to template class object to a function correctly
我有一些类似的代码:
template<class T> class classA
{
public:
classA(uint32_t max) : numElements(max)
{
data = new T[numElements];
}
~classA() {delete[] data;}
uint32_t size()
{
return numElements;
}
T *data;
private:
const int numElements;
};
class classB
{
public:
classB(uint8_t* adress) : ptr(adress){}
void someFunction(classA<class T>* x)
{
uint8_t size = sizeof(T);
/*
do some stuff with the type size of T
*/
T* ptr1 = (T*)ptr; // create new pointer with same adress as ptr but different data type
/*
write some data from ptr1[i] to x->A[i]
*/
}
private:
uint8_t* ptr;
};
int main()
{
classB B(/*some memory adress*/);
classA<uint16_t> A(5)
B.someFunction(&A);
}
这个代码(这里非常简化(应该可以让类B的对象从特定的内存地址开始将数据写入类a对象的数据字段,无论类a中的数据数组是哪种类型。
正如所写的,编译器给出了一些错误:
将"sizeof"应用于不完整类型"T"无效
无效使用不完整的类型"class T"(由于someFunction中的指针填充(
- 无效参数"(因为调用了B.someFunction(&A((
- 对"classB::someFunction(classA<>*("的调用没有匹配的函数
我的问题是:
为了达到以下功能,我必须更改什么?应该允许给
someFunction
的指针具有任意数据类型,并且上面显示的操作应该在没有不完整类型错误的情况下工作。在main中调用someFunction的正确synthax是什么?
我已经尝试过不同的东西,但没有任何帮助:-(
为了实现以下功能,我需要更改什么?应该允许给
someFunction
的指针具有任意数据类型,并且上面显示的操作应该在没有不完整类型错误的情况下工作。
因此someFunction
本身需要是一个模板。因此,它需要适当的template
标头:
template<class T>
void someFunction(classA<T>* x)
{
uint8_t size = sizeof(T);
/*
do some stuff with the type size of T
*/
T* ptr1 = (T*)ptr; // create new pointer with same adress as ptr but different data type
/*
write some data from ptr to x->A[i]
*/
}
除此之外,您的语法看起来是正确的。
相关文章:
- QMetaObject invokeMethod的基于函数指针的语法
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- c++r值引用应用于函数指针
- 模板函数指针和lambda
- 是否可以将llvm::FunctionType转换为C/C++原始函数指针
- 带有类的函数指针
- () 函子后面的括号,而不是函数指针?
- 全局作用域中函数指针的赋值
- 使用"Task"函数指针队列定义作业管理器
- 将成员函数指针作为参数传递给模板方法
- 如何创建对象函数指针C++映射?
- 匹配函数指针作为模板参数?
- 通过函数指针定义类范围之外的方法
- 存储在类中的函数指针
- C++从函数指针数组调用函数
- 将返回值存储在函数指针数组的指针中是如何工作的?
- 整数键映射到头文件中的成员函数指针
- 从类成员函数到类 C 函数指针的转换
- 如何将内联匿名函数分配给C++函数指针
- 将字符缓冲区强制转换为函数指针