微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c – 使用迭代器de-reference的decltype编译错误

在这里错过了什么?为什么我不能使用decltype来定义迭代器的value_type?当我使用decltype而不是iterator_traits时,下面的代码会产生难以理解的编译时错误,但前提是我还使用value_type来声明向量.

Visual Studio 2017,C 17 rev. 15.6预览

#include <vector>
template<class Ptr >
void foo(Ptr beg) {
    *beg = 1;  // Cool,babies.
//  using value_type = decltype(*beg); // COMPILER ERROR when buf declared below
    using value_type = typename std::iterator_traits<Ptr>::value_type;
    std::vector<value_type> buf(1); // Remove this and decltype compiles.
}

int main() {
    std::vector<int> bar(1);
    foo(std::begin(bar));
    *(std::begin(bar)) = 1;
    return 0;
}

按要求…

error C2528: 'const_pointer': pointer to reference is illegal

解决方法

这有同样的原因,当你有:

void foo(int *beg)

然后

decltype(*beg)

不给你一个int.你得到一个int&这里.基本上,这就是你的使用声明最终得到的结果:一个参考,一个不请自来的搭便车者.

如果你坚持使用decltype,你可以这样做:

using value_type = typename std::remove_reference<decltype(*beg)>::type;

为了抛弃不受欢迎的搭便车者.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐