当前位置:  开发笔记 > 编程语言 > 正文

使用decltype返回迭代器

如何解决《使用decltype返回迭代器》经验,为你挑选了1个好方法。

我有这门课:

template 
class Hybrid
{
public:
    Hybrid() : m_activeStackSize(0) {}

private:
    std::list data;

    size_t m_activeStackSize;

    auto internal_peek() -> decltype(data)::iterator
    {
        if (m_activeStackSize) // peek from stack
        {
            decltype(data)::iterator itr = data.end();
            std::advance(itr, -1);
            return itr;
        }
        else //peek from queue
        {
            decltype(data)::iterator itr = data.begin();
            return itr;
        }
    }
};

在Microsoft Visual Studio 2015上尝试编译时,我得到:

main.cpp(12):错误C3646:'iterator':未知的覆盖说明符

我不明白为什么它不会让我返回一个iterator类型std::list的身体代码:

decltype(data)::iterator itr = data.end();

decltype(data)::iterator itr = data.begin();

编译成功.

我如何成功地成功返回std::list iterator使用decltype

删除-> decltype(data)::iterator确实编译成功.

编辑: 使用GCC typename进行decltype 编译并为每个编译添加正常,MSVC仍然出错.



1> R Sahu..:

decltype(data)::iterator是一种依赖类型.因此,你必须使用typename.

auto internal_peek() -> typename decltype(data)::iterator
                       //  ^^^^^ here
{
    if (m_activeStackSize) // peek from stack
    {
        typename decltype(data)::iterator itr = data.end();
        // ^^^^^ and here
        std::advance(itr, -1);
        return itr;
    }
    else //peek from queue
    {
        typename decltype(data)::iterator itr = data.begin();
        // ^^^^^ and here
        return itr;
    }
}

可能为MSVC工作.

// Declare iterator as a type.
using iterator = typename std::list::iterator;

iterator internal_peek()
{
    if (m_activeStackSize) // peek from stack
    {
        iterator itr = data.end();
        std::advance(itr, -1);
        return itr;
    }
    else //peek from queue
    {
        iterator itr = data.begin();
        return itr;
    }
}


编辑了我的问题.GCC接受它,MSVC仍然没有使用相同的错误消息.
推荐阅读
wangtao
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有