对std::list<T>的封装

36 篇文章 2 订阅

由于工作的原因,需要在线程安全的情况下对std::list<T>进行该list进行访问,因此就简单的封装了下,代码如下:

template<typename T>
class List {
public:
    List () {}
    ~List () {}

    void PushBack(const T& value) {
        boost::mutex::scoped_lock lock(mutex_);
        element_list_.push_back(value);
    }

    T Front() {
        boost::mutex::scoped_lock lock(mutex_);
        return element_list_.front();
    }

    void PopFront() {
        boost::mutex::scoped_lock lock(mutex_);
        element_list_.pop_front();
    }

    bool Empty() {
        boost::mutex::scoped_lock lock(mutex_);
        return element_list_.empty();
    }

    void Resize(const size_t& size) {
        boost::mutex::scoped_lock lock(mutex_);
        element_list_.resize(size);
    }

    size_t Size() {
        boost::mutex::scoped_lock lock(mutex_);
        return element_list_.size();
    }

private:
    boost::mutex   mutex_;
    std::list<T>   element_list_;

private:
    List (const List &);
    List & operator=(const List &);
};

调用方式:
List<string*> list_;
auto item = list_.Pop();
list_.PopFront();

// 删除时的调用方式
while (list_.Size() > 0) {
    auto item = list_.Front();
    list_.PopFront();
    delete item;
    item = nullptr;
}

构造函数中对list_中PushBack(value)元素,析构函数中释放元素占用的内存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值