从 std::vector中删除元素>

发布于 2024-12-10 14:15:52 字数 389 浏览 0 评论 0原文

我的编译器抱怨。

#include <iostream>
#include <vector>
using namespace std;

int main(){

        vector<string> vec[2];
        vec[0].push_back("test1");
        vec[0].push_back("test2");

        cout << vec[0][0] << endl;
        vec[0].erase(vec.begin());
        cout << vec[0][1] << endl;

}

当我调用擦除时出了什么问题?

My compiler complains.

#include <iostream>
#include <vector>
using namespace std;

int main(){

        vector<string> vec[2];
        vec[0].push_back("test1");
        vec[0].push_back("test2");

        cout << vec[0][0] << endl;
        vec[0].erase(vec.begin());
        cout << vec[0][1] << endl;

}

What is wrong when I call erase?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

迷途知返 2024-12-17 14:15:52

vec 是一个 vector 数组。我相信你的意思是 vec[0].begin() 像这样:

vec[0].erase(vec[0].begin());

vec is an array of vector<string>s. I believe you meant vec[0].begin() like so:

vec[0].erase(vec[0].begin());
埋葬我深情 2024-12-17 14:15:52
    vec[0].erase(vec[0].begin());
    cout << vec[0][1] << endl;

删除第一个元素后,就只剩下一个了。该元素位于位置 0,这意味着索引 1 超出范围 -> 1。未定义的行为。

    vec[0].erase(vec[0].begin());
    cout << vec[0][1] << endl;

After you erased the first element, there's only one left. This one element is at position 0, which means index 1 is off bounds -> undefined behaviour.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文