Jiv*_*son 3 c++ templates decltype visual-c++ c++17
我在这里错过了什么?为什么我不能使用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;
}
Run Code Online (Sandbox Code Playgroud)
按要求...
error C2528: 'const_pointer': pointer to reference is illegal
Run Code Online (Sandbox Code Playgroud)
这有同样的原因,当你有:
void foo(int *beg)
Run Code Online (Sandbox Code Playgroud)
然后
decltype(*beg)
Run Code Online (Sandbox Code Playgroud)
不给你一个int.你会得到一个int &在这里.基本上,这就是你的using声明最终得到的结果:一个参考,一个不请自来的搭便车者.
如果你坚持使用decltype,你可以这样做:
using value_type = typename std::remove_reference<decltype(*beg)>::type;
Run Code Online (Sandbox Code Playgroud)
为了抛弃不受欢迎的搭便车者.
| 归档时间: |
|
| 查看次数: |
129 次 |
| 最近记录: |