std::unordered_map<Key,T,Hash,KeyEqual,Allocator>:: begin, std::unordered_map<Key,T,Hash,KeyEqual,Allocator>:: cbegin
From cppreference.net
<
cpp
|
container
|
unordered map
|
iterator begin
(
)
noexcept
;
|
(1) |
(自 C++11 起)
(自 C++26 起为 constexpr) |
|
const_iterator begin
(
)
const
noexcept
;
|
(2) |
(自 C++11 起)
(自 C++26 起为 constexpr) |
|
const_iterator cbegin
(
)
const
noexcept
;
|
(3) |
(自 C++11 起)
(自 C++26 起为 constexpr) |
返回指向 * this 首元素的迭代器。
如果 * this 为空,返回的迭代器将等于 end() 。
目录 |
返回值
指向第一个元素的迭代器。
复杂度
常量。
示例
运行此代码
#include <cmath> #include <iostream> #include <unordered_map> struct Node { double x, y; }; int main() { Node nodes[3] = {{1, 0}, {2, 0}, {3, 0}}; // mag 是一个映射,将 Node 的地址映射到其在平面中的模长 std::unordered_map<Node*, double> mag = { { nodes + 0, 1 }, { nodes + 1, 2 }, { nodes + 2, 3 } }; // 将每个 y 坐标从 0 更改为模长 for (auto iter = mag.begin(); iter != mag.end(); ++iter) { auto cur = iter->first; // 指向 Node 的指针 cur->y = mag[cur]; // 也可以使用 cur->y = iter->second; } // 更新并打印每个节点的模长 for (auto iter = mag.begin(); iter != mag.end(); ++iter) { auto cur = iter->first; mag[cur] = std::hypot(cur->x, cur->y); std::cout << "The magnitude of (" << cur->x << ", " << cur->y << ") is "; std::cout << iter->second << '\n'; } // 使用基于范围的 for 循环重复上述操作 for (auto i : mag) { auto cur = i.first; cur->y = i.second; mag[cur] = std::hypot(cur->x, cur->y); std::cout << "The magnitude of (" << cur->x << ", " << cur->y << ") is "; std::cout << mag[cur] << '\n'; // 注意:与上面的 std::cout << iter->second << '\n'; 不同, // std::cout << i.second << '\n'; 将不会打印更新后的模长 } }
可能的输出:
The magnitude of (3, 3) is 4.24264 The magnitude of (1, 1) is 1.41421 The magnitude of (2, 2) is 2.82843 The magnitude of (3, 4.24264) is 5.19615 The magnitude of (1, 1.41421) is 1.73205 The magnitude of (2, 2.82843) is 3.4641
参见
|
返回指向末尾的迭代器
(公开成员函数) |
|
|
(C++11)
(C++14)
|
返回指向容器或数组起始位置的迭代器
(函数模板) |