簡體   English   中英

不匹配 operator== (weak_ptr, const weak_ptr)

[英]No match for operator== (weak_ptr, const weak_ptr)

我有以下數據結構:

shared_ptr<vector<shared_ptr<Drawable>>> foo;

還有一個帶有函數的 Renderer 類:

void addObject(weak_ptr<T> _obj) const

此函數只是將 _obj 推回

mutable vector<weak_ptr<T>> m_objects;

當我嘗試以下操作時:

Renderer r;
for(auto& d: *foo) {
    r.addObject(d);
}

GCC 5.1 出現以下錯誤:

error: no match for 'operator==' (operand types are 'std::weak_ptr<Drawable>' and 'const std::weak_ptr<Drawable>')|

我不明白 const 來自哪里。

foo 

無論如何都不是 const,並且 addObject 不接受 const weak_ptr。

編輯:我認為我太小了。 這是 addObject 的內容:

void addObject(std::weak_ptr<T> _obj) const {
        auto it = std::find(m_objects.begin(), m_objects.end(), _obj);

        if(it == m_objects.end()) {
            m_objects.push_back(_obj);
        }
    };

如果我注釋掉除實際 push_back 行之外的所有內容,它會起作用。 我猜迭代器將自己分配為 constweak_ptr 的迭代器。 如果它已經存在,我只想避免將它添加到向量中。

weak_ptr本身沒有運算符 ==,因此您無法在向量中找到它。 您應該將其轉換為 shared_ptr,然后才進行比較。 所以你應該在每個對象上使用鎖定功能。 或者不比較指針,而是根據某些標准比較對象。

像那樣

#include <memory>
#include <vector>
#include <iostream>
#include <algorithm>

class Object
{
};

class Objects
{
public:
    void addObject(std::weak_ptr<Object> obj)
    {
        auto pos = std::find_if
        (
            objects_.begin(), objects_.end(),
            [&obj](const auto& our_obj)
            {
                return obj.lock() == our_obj.lock();
            }
        );
        if (pos == objects_.end())
        {
            std::cout << "Object added" << std::endl;
            objects_.push_back(obj);
        }
    }
private:
    std::vector<std::weak_ptr<Object>> objects_;
};

int main()
{
    Objects obj_coll;
    std::shared_ptr<Object> obj1 = std::make_shared<Object>();
    obj_coll.addObject(obj1);
    std::shared_ptr<Object> obj2 = std::make_shared<Object>();
    obj_coll.addObject(obj2);
    obj_coll.addObject(obj1);
}

輸出:

Object added
Object added

例子

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM