Russian Qt Forum
Ноябрь 14, 2024, 09:39
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Программирование
>
С/C++
>
2 мапы и вумные указатели
Страниц: [
1
]
2
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: 2 мапы и вумные указатели (Прочитано 14995 раз)
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
2 мапы и вумные указатели
«
:
Октябрь 28, 2015, 09:27 »
Добрый день
Запутался с, казалось бы, простой задачей. Есть 2 мапы
Код
C++ (Qt)
std
::
map
<
Key1
,
Value
*>
map1
;
std
::
map
<
Key2
,
Value
*>
map2
;
Обе мапы хранят полный (и одинаковый) набор Value. В первой мапе эл-ты с разными ключами могут иметь одно и то же значение. Во второй все значения уникальны (а не только ключи). Др словами первая - чтобы собственно пользоваться, вторая - чтобы "валидировать".
Клиент, располагая 2-мя ключами, ищет 2 значения Value в map1 и map2. Если они ненулевые и совпали - все хорошо, возвращается найденный указатель. Иначе если эл-т не найден в map2 то новый Value должен быть создан и помещен в обе мапы. Если найден то замещает значение в map1[key1]. В любом случае если оказалось что старый (замещаемый) эл-т в map1 больше в ней никем не используется - значение должно быть удалено и вычеркнуто из map2. Др словами обе мапы все время должны хранить полный и одинаковый набор значений.
Как же здесь могут помочь вумные указатели?
Спасибо
Записан
ssoft
Программист
Offline
Сообщений: 584
Re: 2 мапы и вумные указатели
«
Ответ #1 :
Октябрь 28, 2015, 13:46 »
Можно хранить в map2 shared_ptr< Value >, а в map1 weak_ptr< Value >, тогда удаление Value из map2 приведет к обнулению указателя weak_ptr в map1.
Только это кажется нерациональным, так как пустые weak_ptr "зависнут" в map1, но все зависит от контекста решаемой задачи.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: 2 мапы и вумные указатели
«
Ответ #2 :
Октябрь 28, 2015, 14:51 »
Цитата: ssoft от Октябрь 28, 2015, 13:46
Можно хранить в map2 shared_ptr< Value >, а в map1 weak_ptr< Value >, тогда удаление Value из map2 приведет к обнулению указателя weak_ptr в map1.
Только это кажется нерациональным, так как пустые weak_ptr "зависнут" в map1, но все зависит от контекста решаемой задачи.
Ну вот, есть же люди которые нормально отвечают, не ссылаясь на "плохая задача"! У меня удаление по Key1 (клиент отвалился), поэтому сделал наоборот, shared в первой, weak во второй (суть та же). А вот с удалением зависших ключей ничего не придумал
Не видно особой опасности, но как-то неаккуратно. Может в самом Value хранить итератор map2? Хорошего впечатления не производит...
Записан
ssoft
Программист
Offline
Сообщений: 584
Re: 2 мапы и вумные указатели
«
Ответ #3 :
Октябрь 28, 2015, 15:20 »
Может в самом Value хранить итератор map2? Хорошего впечатления не производит...
[/quote]
После изменения состава map2, хранимый итератор может стать невалидным.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: 2 мапы и вумные указатели
«
Ответ #4 :
Октябрь 29, 2015, 06:36 »
Цитата: ssoft от Октябрь 28, 2015, 15:20
После изменения состава map2, хранимый итератор может стать невалидным.
Для мапы остается валидным пока сам элемент не удален. Все равно коряво
Записан
Racheengel
Джедай : наставник для всех
Offline
Сообщений: 2679
Я работал с дискетам 5.25 :(
Re: 2 мапы и вумные указатели
«
Ответ #5 :
Октябрь 29, 2015, 09:49 »
По моему, указатели тут не помогут. Лучше дедовским методом прибить значение в map2 и не париться...
Записан
What is the 11 in the C++11? It’s the number of feet they glued to C++ trying to obtain a better octopus.
COVID не волк, в лес не уйдёт
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: 2 мапы и вумные указатели
«
Ответ #6 :
Октябрь 29, 2015, 09:57 »
Цитата: Racheengel от Октябрь 29, 2015, 09:49
По моему, указатели тут не помогут. Лучше дедовским методом прибить значение в map2 и не париться...
А если удаляемые элементы кому-то еще нужны, а мы их будем грохать?
Тут умные указатели как раз очень нужны.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: 2 мапы и вумные указатели
«
Ответ #7 :
Октябрь 29, 2015, 10:06 »
Цитата: Racheengel от Октябрь 29, 2015, 09:49
По моему, указатели тут не помогут. Лучше дедовским методом прибить значение в map2 и не париться...
Т.е. пробегаться по map2 и мочить всех с пустыми значениями? А в какой момент это делать?
Записан
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: 2 мапы и вумные указатели
«
Ответ #8 :
Октябрь 29, 2015, 10:19 »
Цитата: Igors от Октябрь 29, 2015, 10:06
А в какой момент это делать?
Цитата: Igors от Октябрь 28, 2015, 14:51
У меня удаление по Key1 (клиент отвалился)
Вы знаете момент когда удаляется из первого контейнера, почему бы не удалить сразу и из второго?
Записан
Racheengel
Джедай : наставник для всех
Offline
Сообщений: 2679
Я работал с дискетам 5.25 :(
Re: 2 мапы и вумные указатели
«
Ответ #9 :
Октябрь 29, 2015, 11:29 »
Цитата: Old от Октябрь 29, 2015, 09:57
Цитата: Racheengel от Октябрь 29, 2015, 09:49
По моему, указатели тут не помогут. Лучше дедовским методом прибить значение в map2 и не париться...
А если удаляемые элементы кому-то еще нужны, а мы их будем грохать?
Тут умные указатели как раз очень нужны.
Я так понял, что если значения в мапе больше нет - его можно убить, т.к. оно никому не нужно.
Записан
What is the 11 in the C++11? It’s the number of feet they glued to C++ trying to obtain a better octopus.
COVID не волк, в лес не уйдёт
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: 2 мапы и вумные указатели
«
Ответ #10 :
Октябрь 29, 2015, 11:55 »
Цитата: Racheengel от Октябрь 29, 2015, 11:29
Я так понял, что если значения в мапе больше нет - его можно убить, т.к. оно никому не нужно.
И даже нужно. Но как и, главное, когда это делать? Удаление клиента по Key1 ни о чем не говорит, ведь могут быть другие, юзающие тот же Value
Записан
m_ax
Джедай : наставник для всех
Offline
Сообщений: 2095
Re: 2 мапы и вумные указатели
«
Ответ #11 :
Октябрь 29, 2015, 12:13 »
У shared_ptr есть метод unique:
http://en.cppreference.com/w/cpp/memory/shared_ptr/unique
а также use_count.
«
Последнее редактирование: Октябрь 29, 2015, 12:15 от m_ax
»
Записан
Над водой луна двурога. Сяду выпью за Ван Гога. Хорошо, что кот не пьет, Он и так меня поймет..
Arch Linux Plasma 5
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: 2 мапы и вумные указатели
«
Ответ #12 :
Октябрь 29, 2015, 14:10 »
Цитата: m_ax от Октябрь 29, 2015, 12:13
У shared_ptr есть метод unique:
http://en.cppreference.com/w/cpp/memory/shared_ptr/unique
а также use_count.
И что, как я найду удаляемый в map2? На момент удаления имеется только Key1. Неиспользуемый может удаляться и в момент создания нового. Тогда есть оба ключа, но это не помогает - нашли Value по Key1, а по Key2 нет.
Смысл этой конструкции 2 мапов: есть кеши рисования (Value) которые могут шариться. Напр 2 рисуемых объекта шарят один кеш, 2 ключа (Key1) ссылаются на 1 Value. Теперь юзер что-то изменил в одном из рисуемых объектов, и теперь уже нужно 2 кеша. Вот для этого и нужна map2. Если по ключу Key2 (параметры влияющие на рисовние) ничего не найдено в map2, то новый кеш должен быть создан и мапы обновлены.
Записан
Old
Джедай : наставник для всех
Online
Сообщений: 4350
Re: 2 мапы и вумные указатели
«
Ответ #13 :
Октябрь 29, 2015, 14:51 »
Цитата: Igors от Октябрь 29, 2015, 14:10
Смысл этой конструкции 2 мапов: есть кеши рисования (Value) которые могут шариться. Напр 2 рисуемых объекта шарят один кеш, 2 ключа (Key1) ссылаются на 1 Value. Теперь юзер что-то изменил в одном из рисуемых объектов, и теперь уже нужно 2 кеша. Вот для этого и нужна map2. Если по ключу Key2 (параметры влияющие на рисовние) ничего не найдено в map2, то новый кеш должен быть создан и мапы обновлены.
Как то это напоминает implicit sharing, но странно реализованным.
Записан
Авварон
Джедай : наставник для всех
Offline
Сообщений: 3260
Re: 2 мапы и вумные указатели
«
Ответ #14 :
Октябрь 29, 2015, 23:46 »
Плохо соображаю под вечер, но не мультииндекс ли это?
Записан
Страниц: [
1
]
2
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...