繁体   English   中英

如何将泛型类方法模板参数限制为某些类型?

[英]How to restrict generic class method template parameter to certain types?

我已经检查了std::enable_if 以有条件地编译成员函数

但是它对我不起作用。 我需要将类方法的T限制为某些类型。

template<typename T = typename enable_if_t<
    is_same_v<T, long> || is_same_v<T, int> || is_same_v<T, double> 
    || is_same_v<T, float> || is_same_v<T, size_t>>
    >
shared_ptr<Node<T>> LinkedList<T>::AddNumbers(
    shared_ptr<Node<T>> p1, shared_ptr<Node<T>> p2, T carry)
{
    <snip>
}

我得到构建错误:

identifier T is undefined

我正在使用 C++20。 任何建议和见解都值得赞赏。


我尝试了concepts建议的概念,但在执行算术时出现以下构建错误:

error C2676: binary '/': 'T' does not define this operator or 
a conversion to a type acceptable to the predefined operator

我在头文件中有模板类声明,在.cpp文件中有实现。 头文件:

template <typename T> class LinkedList
{
public:
    <snip>
    shared_ptr<Node<T>> AddNumbers(
           shared_ptr<Node<T>>, shared_ptr<Node<T>>, T carry = 0);
};

当我使用@JeJo 的建议时,我遇到了

error C3855: 'LinkedList<T>': template parameter 'T' is
             incompatible with the declaration

尽管其他答案说了什么,成员函数不需要(也不应该)是模板,假设您使用requires 仅当您使用经典的 SFINAE 时才需要这样做。

#include <cstddef>
#include <iostream>
#include <memory>
#include <type_traits>

template <typename T, typename ...P>
concept one_of = (std::is_same_v<T, P> || ...);

template <typename T>
struct Node {};

template <typename T>
class LinkedList
{
public:
    std::shared_ptr<Node<T>> AddNumbers(std::shared_ptr<Node<T>>, std::shared_ptr<Node<T>>, T carry = 0)
    requires one_of<T, int, long, std::size_t, float, double>
    {
        // ...
    }
};

int main()
{
    LinkedList<int> s;
    s.AddNumbers(nullptr, nullptr, 0);

    LinkedList<char> t;
    // t.AddNumbers(nullptr, nullptr, 0);
}

任何布尔条件都可以在requires之后拼写,但为了简洁起见,我添加了一个概念。

暂无
暂无

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

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