post-tree

Dec. 24th, 2022 04:12 pm
amarao: (Default)
[personal profile] amarao
Интернеты говорят, что во-первых Rc<RefCell> не идиоматично для Rust (деревья правильно держать как банальные вектора, содержащие в себе вектора векторов). Во-вторых, я, в целом, всё правильно сделал.

После некоторого кумекания получилось вот так вот, и я не вижу как его сделать существенно компактнее. Может быть, можно уйти от Enum и бального true/false хватит?

Да, получилось.

fn mktree(source: &[Option<i32>]) -> Tree {
if source.is_empty() || source[0].is_none() {
return None;
}
let tree: Tree = new_tree(source[0].unwrap());
let mut buff = VecDeque::new();
buff.push_back((tree.as_ref().cloned(), false));
for val in source[1..].into_iter() {
let subtree = val.and_then(|val| {
let subtree = new_tree(val);
buff.push_back((subtree.as_ref().cloned(), false));
subtree
});
let (node, is_last) = buff.pop_front().unwrap();
if is_last {
node.unwrap().borrow_mut().right = subtree;
} else {
node.as_ref().unwrap().borrow_mut().left = subtree;
buff.push_front((node.as_ref().cloned(), true));
}
}
tree
}

Что меня смущает? Изобилие as_ref().cloned(). Ща буду думать...

Date: 2022-12-25 02:54 pm (UTC)
From: [personal profile] permeakra
охохо. Почитай "Programming Paradigms for Dummies: What Every Programmer Should Know" от Peter Van Roy. Это раз.

Два, да, мутировать в Расте можно из одного места, да, но по умолчанию-то переменные объявляются немутирующими. И это осознанный выбор и политика авторов.

Date: 2022-12-26 10:50 am (UTC)
From: [personal profile] permeakra
То, что компилятор что-то там принимает, в общем случае не всегда плюс. Для уменьшения числа мутаций есть вполне железячные причины. Конкурентные чтение-запись в относительно близкие адреса сильно бьют по производительности на современном железе из-за расходов на когерентность кэша.

Date: 2022-12-26 11:34 am (UTC)
From: [personal profile] permeakra
В расте нет базовой идеологии, к сожалению. Он рос ползучим эмпиризмом, от практики. borrow checker там не единственная фишка, там еще пытаются выкинуть ООП.

Нет, вопросы производительности - не десятое дело. Если вопросы производительности не стоят, раст не нужен, можно взять скалу, котлин и прочее такое. Раст делала изначально мозилла для написания своего файрфокса, а там производительность вполне себе важна. А чтобы компилятору было проще поднимать производительность, нужно максимально урезать мутабельность в коде.

Profile

amarao: (Default)
amarao

February 2026

S M T W T F S
123456 7
8910111213 14
15161718192021
22232425262728

Most Popular Tags

Page Summary

Style Credit

Expand Cut Tags

No cut tags
Page generated Feb. 26th, 2026 02:50 am
Powered by Dreamwidth Studios