首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++模板元编程:重载操作符

C++模板元编程:重载操作符
EN

Stack Overflow用户
提问于 2017-01-13 09:57:32
回答 1查看 326关注 0票数 2

我目前正在尝试模板元编程。我正在尝试使用tmp创建一个有限状态机。我知道web上有几个实现,但我想自己实现一个作为练习。

我试图在基类中为模板化基类的模板化派生重载运算符。假设我们有一个基类:

代码语言:javascript
复制
template<typename Input>
class Base
{
public:
    virtual ~Base() = default;    
    virtual bool operator()(const Input& input) const = 0;

    template<typename Lhs, typename Rhs>
    constexpr Derivation1<Input, Lhs, Rhs> operator||(const Lhs& left, const Rhs& right) const;

    template<typename Lhs, typename Rhs>
    constexpr Derivation2<Input, Lhs, Rhs> operator&&(const Lhs& left, const Rhs& right) const;
};

以及它的两个派生:

代码语言:javascript
复制
template<typename Input, typename... TSpecialized>
class Derivation1 : public Base<Input>
{
public:
    bool operator()(const Input& input) const override
    {
        // ...
    }
};

template<typename Input, typename... TSpecialized>
class Derivation2 : public Base<Input>
{
public:
    bool operator()(const Input& input) const override
    {
        // ...
    }
};

以及我们在基类中声明的运算符的定义:

代码语言:javascript
复制
template <typename Input>
template <typename Lhs, typename Rhs>
constexpr Derivation1<Input, Lhs, Rhs> Base<Input>::operator||(const Lhs& left, const Rhs& right) const
{
    return Derivation1<Input, Lhs, Rhs>();
}

template <typename Input>
template <typename Lhs, typename Rhs>
constexpr Derivation2<Input, Lhs, Rhs> Base<Input>::operator&&(const Lhs& left, const Rhs& right) const
{
    return Derivation2<Input, Lhs, Rhs>();
}

Rhs和Lhs类型也是基类的派生。

当我尝试使用像这样的操作符时:

代码语言:javascript
复制
Derivation3<int, 10, 20> left;
Derivation4<int, 300, 290> right;

auto result = left || right;

我得到一个错误,说没有重载的运算符与参数匹配。这两个派生具有相同的基类型:Base<int>,应在其中声明重载。然后,变量result的类型应该是Derivation1 (就像我们在上面的代码中声明的那样)。

在这种情况下,我如何正确地重载操作符?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-13 10:59:57

我找到了一个解决方案。我已经在基类中创建了一个typedef:

代码语言:javascript
复制
template<typename Input>
class Base
{
public:
    virtual ~Base() = default;    
    virtual bool operator()(const Input& input) const = 0;

    typedef Input inputType;
};

我把操作符重载移到了类之外:

代码语言:javascript
复制
template <typename Lhs, typename Rhs>
constexpr Derivation1<typename Lhs::inputType, Lhs, Rhs> operator||(const Lhs& left, const Rhs& right)
{
    return Derivation1<typename Lhs::inputType, Lhs, Rhs>();
}

template <typename Lhs, typename Rhs>
constexpr Derivation2<typename Lhs::inputType, Lhs, Rhs> operator&&(const Lhs& left, const Rhs& right)
{
    return Derivation2<typename Lhs::inputType, Lhs, Rhs>();
}

这段代码按照预期完美地工作。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41626239

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档