初始化可变模板类中的静态数组
Initialize static array in variadic template class
我有一个可变模板类"InterleavedAttribute",现在我想要一些关于模板中类型的运行时信息("AttributeTypeInfo")。我想在模板类("attributeInfo")中填充一个静态常量数组,然后在运行时使用单个信息的索引来访问该数组,比如object.typeInfo(2),但我不知道怎么做。这是我的:
#include <iostream>
template <typename TYPE> struct GLTypeInfo;
template <>
struct GLTypeInfo<char> { static constexpr unsigned int glType = 0; };
template <>
struct GLTypeInfo<int> { static constexpr unsigned int glType = 1; };
template <>
struct GLTypeInfo<float> { static constexpr unsigned int glType = 2; };
//---------------------------------------------------------------------------
struct AttributeTypeInfo
{
unsigned int nrOfComponents;
unsigned int glType;
unsigned int bytesPerComponent;
unsigned int bytesPerAttribute;
constexpr AttributeTypeInfo(unsigned int _nrOfComponents, unsigned int _glType, unsigned int _bytesPerComponent, unsigned int _bytesPerAttribute)
: nrOfComponents(_nrOfComponents), glType(_glType), bytesPerComponent(_bytesPerComponent), bytesPerAttribute(_bytesPerAttribute)
{}
};
template <typename T>
struct TypeInfoFactory
{
static unsigned int constexpr extent = std::is_array<T>::value ? std::extent<T>::value : 1;
using type = typename std::conditional<std::is_array<T>::value, typename std::remove_extent<T>::type, T>::type;
static constexpr AttributeTypeInfo typeInfo = AttributeTypeInfo(extent, GLTypeInfo<type>::glType, sizeof(type), sizeof(type) * extent);
};
//---------------------------------------------------------------------------
template <typename TYPE, typename ...P> struct InterleavedAttribute
{
static constexpr unsigned int nrOfAttributes = sizeof...(P)+1;
//static constexpr AttributeTypeInfo attributeInfo[sizeof...(P)+1] = { ??? }; // <-- How do I fill this...
TYPE data;
InterleavedAttribute<P...> next;
InterleavedAttribute() {}
InterleavedAttribute(const TYPE & value, const P &... p) : data(value), next(p...) {}
//static constexpr AttributeTypeInfo typeInfo(unsigned int index) { return attributeInfo[index]; } // ...so I can call this later?
};
template <typename TYPE> struct InterleavedAttribute<TYPE>
{
static constexpr unsigned int nrOfAttributes = 1;
static constexpr AttributeTypeInfo attributeInfo[1] = { TypeInfoFactory<TYPE>::typeInfo };
TYPE data;
InterleavedAttribute() {}
InterleavedAttribute(const TYPE & value) : data(value) {}
static constexpr AttributeTypeInfo typeInfo(unsigned int index) { return attributeInfo[0]; }
};
int main() {
InterleavedAttribute<int> ia1(5);
std::cout << "Numer of attributes: " << ia1.nrOfAttributes << std::endl;
std::cout << "Attribute 0, glType: " << ia1.typeInfo(0).glType << std::endl;
InterleavedAttribute<float, int, char> ia3(1.2, 3, 'a');
std::cout << "Numer of attributes: " << ia3.nrOfAttributes << std::endl;
//std::cout << "Attribute 0, glType: " << ia3.typeInfo(0).glType << std::endl; <-- Trying to get type information here
}
代码在Coliru这里。我找到了这个答案,而且很接近,但我仍然不知道如何得到我想要的。。。
您可以使用std::tuple
:执行以下操作
template <typename ...Ts> struct InterleavedAttribute
{
static constexpr unsigned int nrOfAttributes = sizeof...(Ts);
static constexpr AttributeTypeInfo attributeInfo[sizeof...(Ts)] = {
TypeInfoFactory<Ts>::typeInfo...
};
std::tuple<Ts...> data;
InterleavedAttribute() {}
InterleavedAttribute(const Ts&... args) : data(args...) {}
static constexpr AttributeTypeInfo typeInfo(unsigned int index) {
return attributeInfo[index];
}
template <unsigned int I>
auto attribute() -> decltype(std::get<I>(data)) { return std::get<I>(data); }
template <unsigned int I>
auto attribute() const -> decltype(std::get<I>(data)) { return std::get<I>(data); }
};
// odr-used, so definition required for linker.
template <typename ...Ts>
constexpr AttributeTypeInfo InterleavedAttribute<Ts...>::attributeInfo[sizeof...(Ts)];
演示
相关文章:
- C++17中函数模板中的静态数组初始化(MSVC 2019)
- 静态数组的自由动态数组
- 如何在C++中删除静态数组?
- 为什么 &a 和 c++ 中的静态数组相同?
- 为什么静态数组成员变量在调用对象的实例后不显示任何内容?
- C++ 返回指向函数内定义的静态数组的指针是否有效?
- 将在堆栈上声明的元素添加到静态数组
- const_cast静态数组以添加恒常性
- 动态分配的数组和静态数组之间的区别
- C++编译时使用 constexpr 字符数组指针分配静态数组?
- 我可以使用 constexpr 函数声明一个静态数组吗?
- 使用 lambda 初始化静态数组
- 为什么从函数返回数组时需要将数组声明为静态数组.(C++)
- 根据模板值确定的静态数组大小
- 如何使用 PHP-CPP 在 PHP 类中添加静态数组
- 包含不同大小静态数组的类的多个实例
- 从我的对象返回静态数组
- 如何避免在类中显式指定静态数组的大小
- 编译类型的时静态数组
- 来自函数参数的 C++ 静态数组声明