Erasing vector::end from vector(从向量中擦除向量::end)
问题描述
当我使用时它是否正常工作(什么都不做)
Does it works correct(does nothing) when I use
vector<T> v;
v.erase(v.end());
我想使用类似的东西
v.erase(std::find(...));
我应该 if
是 v.end()
还是不是?
C++.com 和 CPPreference
Should I if
is it v.end()
or not?
There is no info about it on C++.com and CPPreference
推荐答案
标准并没有完全说明,但是 v.erase(q)
是定义的,擦除指向的元素通过 [sequence.reqmts]
中的 q
".这意味着 q
必须实际指向一个元素,而结束迭代器没有.传入 end 迭代器是未定义的行为.
The standard doesn't quite spell it out, but v.erase(q)
is defined, "Erases the element pointed to by q
" in [sequence.reqmts]
. This means that q
must actually point to an element, which the end iterator doesn't. Passing in the end iterator is undefined behavior.
不幸的是,你需要写:
auto it = std::find(...);
if (it != <the part of ... that specifies the end of the range searched>) {
v.erase(it);
}
当然,你可以定义:
template typename<Sequence, Iterator>
Iterator my_erase(Sequence &s, Iterator it) {
if (it == s.end()) return it;
return s.erase(it);
}
my_erase(v, std::find(v.begin(), v.end(), whatever));
关联容器上的
c.erase()
返回 void
,因此要将这个模板推广到所有容器,您需要一些 ->decltype
动作.
c.erase()
on an associative container returns void
, so to generalize this template to all containers you need some -> decltype
action.
这篇关于从向量中擦除向量::end的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:从向量中擦除向量::end
基础教程推荐
- 如何在 C++ 中处理或避免堆栈溢出 2022-01-01
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17
- C++,'if' 表达式中的变量声明 2021-01-01
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01
- 设计字符串本地化的最佳方法 2022-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 运算符重载的基本规则和习语是什么? 2022-10-31
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04