std::vector<T,Allocator>::operator[]
来自cppreference.com
reference operator[]( size_type pos ); |
(1) | (C++20 起为 constexpr ) |
const_reference operator[]( size_type pos ) const; |
(2) | (C++20 起为 constexpr ) |
返回位于指定位置 pos 的元素的引用。不进行边界检查。
参数
pos | - | 要返回的元素的位置 |
返回值
到所需元素的引用。
复杂度
常数。
注解
不同于 std::map::operator[],此运算符决不向容器插入新元素。通过此运算符访问不存在的元素是未定义行为。
示例
下列代码使用 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
参阅
带越界检查访问指定的元素 (公开成员函数) |