Namespaces
Variants

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

From cppreference.net

reference operator [ ] ( size_type pos ) ;
(1) (自 C++20 起为 constexpr)
const_reference operator [ ] ( size_type pos ) const ;
(2) (自 C++20 起为 constexpr)

返回指定位置 pos 处元素的引用。

pos < size ( ) false ,则行为未定义。

(C++26 前)

pos < size ( ) false

  • 若实现为 强化实现 ,则发生 契约违反 。此外,若契约违反处理程序在“观察”求值语义下返回,则行为未定义。
  • 若实现非强化实现,则行为未定义。
(C++26 起)

目录

参数

pos - 要返回元素的位置

返回值

对所请求元素的引用。

复杂度

常量。

注释

std::map::operator[] 不同,该运算符永远不会向容器中插入新元素。通过此运算符访问不存在的元素将导致未定义行为 ,除非实现进行了强化处理 (since C++26)

示例

以下代码使用 operator [ ] std:: vector < int > 进行读写操作:

#include <vector>
#include <iostream>
int main()
{
    std::vector<int> numbers{2, 4, 6, 8};
    std::cout << "Second element: " << numbers[1] << '\n';
    numbers[0] = 5;
    std::cout << "All numbers:";
    for (auto i : numbers)
        std::cout << ' ' << i;
    std::cout << '\n';
}
// Since C++20 std::vector can be used in constexpr context:
#if defined(__cpp_lib_constexpr_vector) and defined(__cpp_consteval)
// Gets the sum of all primes in [0, N) using sieve of Eratosthenes
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's memory is released here
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

输出:

Second element: 4
All numbers: 5 4 6 8

参见

访问指定元素并进行边界检查
(公开成员函数)