Добрый день, я опять попадаю в тупик со временами жизни Задача

наверняка кому-то встречалась: сделать итератор как drain(), только чтобы удалял элемент не перед началом итерации, а после
Почему явно прописанное время жизни ссылки ограничивается временем жизни поля, по которому эта ссылка лежит?
use std::collections::HashSet;
use std::hash::Hash;

struct IdHashDeleteAfterUseIterator<'a, Id> where Id: Eq + Hash {
set: &'a mut HashSet<Id>,
first_done: bool,
}
impl<'a, Id: Eq+Hash> Iterator for IdHashDeleteAfterUseIterator<'a, Id> {
type Item = &'a Id;
fn next (&mut self) -> Option<Self::Item> {
if self.first_done {
if let Some(value_as_key) = self.set.iter().next() {
// https://github.com/rust-lang/rust/issues/27804#issuecomment-406269067
// конечно, я предполагаю, что нет никакого смысла для std обращаться к элементу
// после удаления, но небезинтересно, почему такой сценарий обязан быть unsafe
let key_ref = unsafe{&*(value_as_key as *const _)};
self.set.remove(key_ref);
}
}
self.first_done = true;
// эта строчка не компилится
self.set.iter().next()
// эти строчки компилятся, но может я создаю опасность?
//let self_ref: &HashSet<Id> = unsafe{&*(self.set as *const _)};
//self_ref.iter().next()
}
}
На medium говорят, что времена жизни в прототипе fn next<'a, 'b>(&'a self) -> Option<&'b Self::Item> сделаны такими, чтобы возвращаемое значение не было ограничено временем жизни итератора, но ошибка компилятора противоположна этому.
first, the lifetime cannot outlive the anonymous lifetime defined here
self.set.iter().next()
^^^^
...so that reference does not outlive borrowed content
fn next (&mut self) -> Option<Self::Item> {
^^^^^^^^^
but, the lifetime must be valid for the lifetime `'a` as defined here...
self.set.iter().next()
^^^^^^^
...so that the types are compatible
impl<'a, Id: Eq+Hash> Iterator for ...
^^
К допустимости unsafe я пришёл как к варианту ответа на users.rust-lang, но там же ссылаются на реализацию итератора в too-many-lists без unsafe, и там почему-то таких ошибок нет - причина вероятно в обёртке через Option но мне совсем неясно, с фига ли Option компилятору достаточно, а почти тех же моих времён жизни, просто без обёртки - нет

Спасибо

4 ответов

12 просмотров

рабочий исходник лучше ссылкой на play.rust-lang.org

а если попробовать итератор сделать частью структуры?

makaleks-Maksimov Автор вопроса
Alexey Ermakov
а если попробовать итератор сделать частью структу...

Владение полей структуры друг-другом вроде бы тот ещё враг borrow checker'а, плюс это часто просто не нужно (сталкивался и не только я), плюс это кажется опять будет работать только с fn next<'a>(&'a self)->Option<&'a Item>, что противоречит типажу Iterator

Похожие вопросы

Обсуждают сегодня

Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
7
Всем привет. Не понимаю, в чём тут шутка юмора. Убирается только разрешение на send_messages. А send_media_messages остаётся. Как сделать, чтобы оба убирались? await b...
Alexander
2
Есть тут кто занимается разработкой серваков майна? Или знакомые
meow *
3
'frakturBold' => ['𝖆', '𝖇', '𝖈', '𝖉', '𝖊', '𝖋', '𝖌', '𝖍', '𝖎', '𝖏', '𝖐', '𝖑', '𝖒', '𝖓', '𝖔', '𝖕', '𝖖', '𝖗', '𝖘', '𝖙', '𝖚', '𝖛', '𝖜', '𝖝', '𝖞', '𝖟', '𝕬', '𝕭', '𝕮', '𝕯'...
Roma
4
Есть ли лимиты на кол-во вебхук по домену? Стоит в данный момент 900+ ботов и бывает бот перестает отвечать (не приходят вебхуки) 🐒 Помогает только перезапуск
ᅠ [ Кому не ответил, дублируйте ]
11
а что делать если тебя убивают на картах?
Yarik yarik kyda ti lezesh
43
Товарищи, здравствуйте Подскажите, пожалуйста, может кто-нибудь сталкивался с такой задачей Через вебапку можно сканировать qr-код, а есть ли возможность считывать nfc?
Artem Stormageddon
8
Карта сайта