std::vector<T,Allocator>::operator[]
来自cppreference.com
<tbody>
</tbody>
reference operator[]( size_type pos ); |
(1) | (C++20 起为 constexpr) |
const_reference operator[]( size_type pos ) const; |
(2) | (C++20 起为 constexpr) |
返回位于指定位置 pos 的元素的引用。
如果实现未加固,则(C++26 起)不进行边界检查。
|
如果 |
(C++26 前) |
|
如果 |
(C++26 起) |
参数
| pos | - | 要返回的元素的位置 |
返回值
到所需元素的引用。
复杂度
常数。
注解
与 std::map::operator[] 不同,此运算符不会向容器插入新元素。若实现未被加固,则(C++26 起)通过此运算符访问不存在的元素是未定义行为。
示例
下列代码使用 operator[] 读取并写入 std::vector<int>:
运行此代码
#include <vector>
#include <iostream>
int main()
{
std::vector<int> numbers{2, 4, 6, 8};
std::cout << "第二个元素:" << numbers[1] << '\n';
numbers[0] = 5;
std::cout << "所有数:";
for (auto i : numbers)
std::cout << ' ' << i;
std::cout << '\n';
}
// C++20 起,std::vector 可以用在 constexpr 语境中:
#if defined(__cpp_lib_constexpr_vector) and defined(__cpp_consteval)
// 使用 Eratosthenes 筛法获得 [0, N) 中所有素数的和
consteval auto sum_of_all_primes_up_to(unsigned N)
{
if (N < 2)
return 0ULL;
std::vector<bool> is_prime(N, true);
is_prime[0] = is_prime[1] = false;
auto propagate_non_primality = [&](decltype(N) n)
{
for (decltype(N) m = n + n; m < is_prime.size(); m += n)
is_prime[m] = false;
};
auto sum{0ULL};
for (decltype(N) n{2}; n != N; ++n)
if (is_prime[n])
{
sum += n;
propagate_non_primality(n);
}
return sum;
} //< vector 的内存在这里释放
static_assert(sum_of_all_primes_up_to(42) == 0xEE);
static_assert(sum_of_all_primes_up_to(100) == 0x424);
static_assert(sum_of_all_primes_up_to(1001) == 76127);
#endif
输出:
第二个元素:4
所有数:5 4 6 8
参阅
| 带越界检查访问指定的元素 (公开成员函数) |