繁体   English   中英

一个模板化 class 的成员 function 中的模板类型扣除

[英]template type deduction in a member function of a templated class

主function第一行扣减失败,不加额外模板参数如何解决

#include <iostream>

template <typename T>
class myVec{
    size_t _size{};
    size_t capacity{};
    T* data{};

public:
    myVec(size_t size = 0, T value = T{}):_size{size}, capacity{2 * _size}{
        data = new T[capacity];
        for(size_t index{}; index < _size; index++)
            data[ index ] = T{};
    }

    template <typename ... Ts>
    myVec( Ts&& ... vals):myVec{ sizeof...(vals)}{


        size_t index{};
        ((data [ ++index ] = vals),...);
    }

    ~myVec(){
        delete[] data;
    }
    size_t size( ){
        return _size;
    }
    /*the rest */

};

int main(){
    myVec vec {1, 32, 5, 6};

    for(size_t index{}; index < vec.size(); ++index )
        std::cout << vec[ index ] << " ";
}

如果 Class 模板与构造函数完全匹配,则只能隐式推断 class 模板参数,例如:

template <typename T>
class myVec
{
    ...
    myVec(int, T); // T can be deduced since it's from the class template
    ...
};
...
myVec(5,5); // deduces myVec<int>

另一方面,构造函数模板中的类型不直接参与推导——因为推导的类型不一定与 class 模板的类型相同:

template <typename T>
class myVec
{
    ...
    template <typename U>
    myVec(int, U); // U may not be the same as T!
    ...
    template <typename...Ts>
    myVec(Ts&&...); // All 'Ts' types may not be the same as 'T'
    ...
};

解决此问题的方法是使用用户定义的演绎指南 这些允许您定义在面对其他模棱两可的构造函数表达式时推导出的类型。 在您的情况下,您可能正在寻找类似的东西:

template <typename...Ts> 
myVec(Ts...) -> myVec<std::common_type_t<Ts...>>;

注意: std::common_type_t用于获取所有可变参数类型的公共类型。 它在<type_traits> header 中定义。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM