c++ - 不知道为什么我会收到关于 std::size_t 不包含参数包的编译错误

标签 c++ variadic-templates variadic-functions

我这里有这个类:

template<typename ClassType, std::size_t... Dims>
class MatrixCell {
private:
    std::vector<std::size_t> coordinateIndices_;
    ClassType data_;

public:
    MatrixCell() : coordinateIndices_{Dims...} {}

    //template<typename ClassType, std::size_t... Dims>
    void addItem( ClassType item, std::size_t... Dims) {
        if ( !checkIndex( Dims... ) ) {
            std::ostringstream strStream;
            strStream << __FUNCTION__ << " current index doesn't exist.";
            Logger::log( strStream, Logger::TYPE_ERROR );
            throw ExceptionHandler( strStream );
        } else {
            data_ = item;
        }
    }

private:
    //template<typename ClassType, std::size_t... Dims>
    bool checkIndex( std::size_t... Dims ) {
        return true;
    }
};

我遇到了这个编译器错误:

1>------ Build started: Project: FileTester, Configuration: Debug Win32 ------
1>  Matrix.cpp
1>c:\users\skilz80\documents\visual studio 2015\projects\filetester\filetester\matrix.h(155): error C3543: 'std::size_t': does not contain a parameter pack
1>  c:\users\skilz80\documents\visual studio 2015\projects\filetester\filetester\matrix.h(171): note: see reference to class template instantiation 'MatrixCell<ClassType,Dims...>' being compiled
1>c:\users\skilz80\documents\visual studio 2015\projects\filetester\filetester\matrix.h(168): error C3543: 'std::size_t': does not contain a parameter pack
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
};

我对错误代码的理解没有问题;我无法理解到底是什么导致了错误,并且不确定在我尝试过很多事情的地方正确的语法是什么。

我有一个类似的类,编译得很好,如下所示:

// DimensionPack & Helper Struct
struct MatrixDimensionOddOrEven {
    const unsigned int even_or_odd; 
    explicit MatrixDimensionOddOrEven( unsigned int odd_or_even ) : even_or_odd( test( odd_or_even ) ) {}

private:
    const unsigned int test( unsigned int value ) const {
        if ( value == 0 ) {
            std::ostringstream strStream;
            strStream << __FUNCTION__ << "invalid number: " << value << " must be >= 1.";
            Logger::log( strStream, Logger::TYPE_ERROR );
            throw ExceptionHandler( strStream );
        }
        return ( ((value % 2) == 0) ? EVEN : ODD );
    }
}; typedef MatrixDimensionOddOrEven MatDimOddEven;

template <std::size_t... Dims>
class DimensionPack {
public:
    std::vector<std::size_t> dimensions;
    std::vector<unsigned int> even_or_odd;
    const std::size_t total_dimensions = sizeof...(Dims);
    const std::size_t total_elements = countElements();

public:
    DimensionPack() : dimensions{Dims...},
        even_or_odd{ MatrixDimensionOddOrEven{Dims}.even_or_odd...} {
    }

private:
    std::size_t countElements() {
        std::size_t val = 1; // Don't Init to 0 otherwise multiplication won't work here!
        for ( std::size_t n = 0; n < dimensions.size(); n++ ) {
            val *= dimensions.at( n );
        }
        return val;
    }
}; // DimensionPack

因此,指向正确方向的指针将非常有用,我们将不胜感激。

最佳答案

你可能想要这个:

void addItem( ClassType item, decltype(Dims)... dims ) {
    if ( !checkIndex( dims... ) ) {

bool checkIndex( decltype(Dims)... dims ) {

不幸的是,VC++ 无法编译它。这可能是一个编译器缺陷(不太确定,因为我没有尝试根据标准验证这一点,但 g++ 和 clang 都编译它)。幸运的是我们可以解决它。我们并不真的需要 decltype,我们需要一些接受 std::size_t 常量表达式的东西,忽略它并返回 std::size_t。类似于常量类型级函数。例如:

template <std::size_t>
struct const_size_t
{
    using type = std::size_t;
};

并像这样使用它:

void addItem( ClassType item, typename const_size_t<Dims>::type... dims) 

Live demo

关于c++ - 不知道为什么我会收到关于 std::size_t 不包含参数包的编译错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42043215/

相关文章:

c - 编写一个函数来处理可变数量的参数

c++ - 工作函数重载如何使用可变参数进行解析?

C++、TR1、正则表达式和 boost

c++ - 如何将qml a textField的文本转换为float和int

c++ - 为 C 数学函数调用 MSVC 内置/内在函数

c++ - 如何对 C++ 可变参数模板进行递归?

c++ - 区分 const char[N] 和 std::string 的类型特征?

c - 如何模糊 stdarg.h 函数?

c++ - 在迭代 map 时向/从 map 添加/删除元素是否安全

c++ - 哪个编译器符合标准?