在 C++ 标准库中,std::prev
是一个函数模板,用于获取给定迭代器的前一个迭代器。其原型如下:
template<class BidirectionalIterator>
BidirectionalIterator prev(BidirectionalIterator it,
typename std::iterator_traits<BidirectionalIterator>::difference_type n = 1);
这里,it
是一个双向迭代器(BidirectionalIterator),n
是一个可选参数,表示要向前移动的距离,默认值为 1。
std::prev
函数返回一个新的迭代器,该迭代器指向 it
之前的第 n
个元素。如果 n
为正数,则返回的迭代器将向前移动;如果 n
为负数,则返回的迭代器将向后移动。
需要注意的是,std::prev
函数不会检查返回的迭代器是否有效。因此,在使用 std::prev
时,需要确保返回的迭代器在容器的范围内。否则,使用无效的迭代器可能导致未定义的行为。
以下是一个简单的示例,展示了如何使用 std::prev
函数:
#include<iostream>
#include<vector>
int main() {
std::vector<int> v = {1, 2, 3, 4, 5};
auto it = v.begin() + 2; // it 指向第三个元素(值为 3)
auto prev_it = std::prev(it); // prev_it 指向第二个元素(值为 2)
std::cout << *prev_it<< std::endl; // 输出 2
return 0;
}
在这个示例中,我们创建了一个包含 5 个整数的 std::vector
。然后,我们使用 std::prev
函数获取指向第二个元素的迭代器,并将其打印到控制台。