std::move_iterator<Iter>::operator*,->
来自cppreference.com
< cpp | iterator | move iterator
(1) | ||
reference operator* () const; |
(C++11 起) (C++17 前) |
|
constexpr reference operator* () const; |
(C++17 起) | |
(2) | ||
pointer operator->() const; |
(C++11 起) (C++17 前) |
|
constexpr pointer operator->() const; |
(C++17 起) (C++20 中弃用) |
|
返回到当前元素的右值引用或指针。
1) 等价于 static_cast<reference>(*base()) (C++20 前)ranges::iter_move(base()) (C++20 起) 。
2) 等价于
base()
。参数
(无)
返回值
1) 到当前元素的右值引用或其副本。
2) 底层迭代器的副本。若直接使用
->
则最终返回指向当前元素的指针。注解
注意若直接使用 ->
则 (2) 最终返回指针。解引用指针时,返回值是左值。这可能导致非有意的行为。
示例
运行此代码
#include <iomanip> #include <iostream> #include <iterator> #include <string> #include <vector> void print(auto rem, auto const& v) { for (std::cout << rem; auto const& e : v) std::cout << quoted(e) << ' '; std::cout << '\n'; } int main() { std::vector<std::string> p{"alpha", "beta", "gamma", "delta"}, q; print("1) p: ", p); for (std::move_iterator it{p.begin()}, end{p.end()}; it != end; ++it) { it->push_back('!'); // 调用 -> string::push_back(char) q.emplace_back( *it ); } print("2) p: ", p); print("3) q: ", q); std::vector v{1,2,3}; std::move_iterator it{v.begin()}; // *it = 13; // 错误:将右值用作左值 }
输出:
1) p: "alpha" "beta" "gamma" "delta" 2) p: "" "" "" "" 3) q: "alpha!" "beta!" "gamma!" "delta!"
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 2106 | C++11 | 若解引用底层迭代器返回纯右值则解引用 move_iterator 能返回悬垂引用
|
替而返回对象 |
参阅
(C++11) |
按索引访问元素 (公开成员函数) |