std::list为空时调用pop_front的访问越界问题

std::list为empty时调用pop_front导致程序崩溃


如果list中装的是指针,当其为empty时,再调用pop_front可能会返回一个非NULL的值,此时直接使用这个返回的指针会导致内存越界。

#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <list>
#include <unistd.h>
#include <assert.h>

using namespace std;

void Test() // failed
{
    std::list<int *> list;
    int n = 1;
    std::cout << "n address:" << static_cast<void *>(&n) << std::endl;

    while (1)
    {
        list.push_back(&n);
        std::cout << "size:" << list.size() << " front:" << static_cast<void *>(list.front()) << std::endl;
        list.pop_front();
        std::cout << "size:" << list.size() << " front:" << static_cast<void *>(list.front()) << std::endl;

        if (list.empty())
            assert(list.front() == NULL); // 这里会断言失败,若list中为指针时在pop_front前一定要先检查下是否为空,否则会导致访问越界
        usleep(1000*500);
    }
}

void Test2() // pass
{
    std::list<int> list2;
    int n = 1;

    while (1)
    {
        list2.push_back(n);
        std::cout << "size:" << list2.size() << " front:" << list2.front() << std::endl;
        list2.pop_front();
        std::cout << "size:" << list2.size() << " front:" << list2.front() << std::endl;

        if (list2.empty())
            assert(list2.front() == 0); // 这里断言成功
        usleep(1000*500);
    }
}

    int
main( int argc, char **argv )
{
    Test2();
    Test();

    return 0;
}

作者:帅得不敢出门 c++哈哈堂:31843264

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用 `std::unique_ptr` 管理指针对象时,我们可以将其存储在 `std::list` 中,并通过 `std::list` 提供的迭代器来访问对象。 以下是一个示例代码,展示了如何使用 `std::unique_ptr` 存储指针对象,并遍历访问它们: ```c++ #include <iostream> #include <memory> #include <list> class MyClass { public: MyClass(int value) : m_value(value) {} void Print() { std::cout << "Value: " << m_value << std::endl; } private: int m_value; }; int main() { std::list<std::unique_ptr<MyClass>> myList; // 向 list 中添加元素 myList.emplace_back(std::make_unique<MyClass>(10)); myList.emplace_back(std::make_unique<MyClass>(20)); myList.emplace_back(std::make_unique<MyClass>(30)); // 遍历访问指针对象 for (const auto& ptr : myList) { ptr->Print(); } return 0; } ``` 在上面的示例中,我们首先创建了一个 `std::list`,用于存储 `std::unique_ptr<MyClass>`。然后,我们通过 `emplace_back` 函数向 `list` 中添加了三个元素,每个元素都是一个指向 `MyClass` 对象的 `std::unique_ptr`。 最后,我们使用范围 `for` 循环遍历 `list` 中的所有元素,并通过 `->` 运算符来访问指针对象的成员函数。由于 `std::unique_ptr` 重载了 `->` 运算符,因此可以像访问普通指针一样访问对象的成员函数。 需要注意的是,由于 `std::unique_ptr` 是独占所有权的智能指针,因此不能将其拷贝或赋值给其他指针。因此,在遍历访问 `std::list` 中的元素时,我们使用了 `const auto&` 类型的引用,以防止复制 `std::unique_ptr`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值