метода:
std::map::insert_or_assign, который работает по принципу "если ключ есть - заменить значение, если ключа нет - вставить новый"
и std::map::try_emplace, который работает по принципу "если ключ уже есть - ничего не делать, а если нет - вставить новый"
Вопрос:
Почему не добавили std::map::try_assign, который работал бы по принципу "если ключ есть - заменить значение, а если нет - ничего не делать"?
Чем это отличается от поискать и переписать через итератор?
Наверное потому, что в этих двух случаях иначе пришлось бы два раза искать, а в твоем случае, ты можешь сделать find() и если не end(), то поменять его (без повторного поиска).
Никто не предложил такой метод. У вас есть шанс: stdcpp.ru
Тебе, может, еще std::map::value_or добавить? :)
Обсуждают сегодня