std::vector<T,Allocator>::operator[]

来自cppreference.com
< cpp‎ | container‎ | vector

 
 
 
 
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

参阅

带越界检查访问指定的元素
(公开成员函数)