可以使用动态数组作为c++模板类型名吗?

Can I use a dynamic array as C++ template typename?

本文关键字:类型 c++ 动态 数组 可以使      更新时间:2023-10-16

对于下面的代码:

template<typename PatternType>
cl_int enqueueFillBuffer(
    const Buffer& buffer,
    PatternType pattern,
    ::size_t offset,
    ::size_t size,
    const VECTOR_CLASS<Event>* events = NULL,
    Event* event = NULL) const
{
    cl_event tmp;
    cl_int err = detail::errHandler(
        ::clEnqueueFillBuffer(
            object_, 
            buffer(),
            static_cast<void*>(&pattern),
            sizeof(PatternType), 
            offset, 
            size,
            (events != NULL) ? (cl_uint) events->size() : 0,
            (events != NULL && events->size() > 0) ? (cl_event*) &events->front() : NULL,
            (event != NULL) ? &tmp : NULL),
            __ENQUEUE_FILL_BUFFER_ERR);
    if (event != NULL && err == CL_SUCCESS)
        *event = tmp;
    return err;
}

如果数组长度6是静态指定的,则可以编译代码。

queue.enqueueFillBuffer<float[6]>(buffer, nodes, 2345, 123456);

我的问题是如何使长度6成为一个变量并通过编译?由于C99支持动态数组,sizeof(float[n])可以正确获取size(对于代码sizeof(PatternType))。但是我不能让下面的代码通过编译:

int n = 6;
queue.enqueueFillBuffer<float[n]>(buffer, nodes, 2345, 123456);

考虑使用std::array。更一般地说,假设将一个类似stl的容器传递给您的方法。例如,

std::array<float, 6> nodes;
nodes[0] = ...

std::vector<float> nodes;
nodes.resize(6);
nodes[0] = ...

然后是

static_cast<void*>(&pattern),
sizeof(PatternType),

可以用

代替
static_cast<void*>(pattern.data()),
sizeof(typename PatternType::value_type) * pattern.size(), 

编译器可以推断出类型,因此调用该方法就变成了

queue.enqueueFillBuffer(buffer, nodes, 2345, 123456);

无需显式模板参数

答案是没有办法完成它。关于enqueueFillBuffer的实现请参考:https://www.khronos.org/bugzilla/show_bug.cgi?id=1347支持的最大模式大小为ulong16,128字节。