Нет соответствия для оператора == (слабый_птр, конст. Слабый_птр) - PullRequest
0 голосов
/ 06 декабря 2018

У меня есть следующая структура данных:

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 

не является константой ни в коем случае, а addObject не принимает константную слабую_птр.

РЕДАКТИРОВАТЬ: Я думаю, что я был слишком минимальным.Вот содержимое 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.Я предполагаю, что итератор назначает себя в качестве итератора для const weak_ptr.Я просто хочу не добавлять его в вектор, если он уже существует.

1 Ответ

0 голосов
/ 06 декабря 2018

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);
}

output:

Object added
Object added

Пример

...