amarao: (Default)
amarao ([personal profile] amarao) wrote2021-10-08 11:45 am

Rust soundness

Каждый раз, когда я сталкиваюсь с маленькими "но" в Rust'е, это ощущение тщательной продуманности. Например, простейшие fold-функции для итераторов: sum, min, max, any. Например, что должен вернуть max для пустого списка?

В питоне? Enjoy your ValueError exception.

В Rust'е? Max возвращает Some с результатом. Или None (который вариант от Option, а не абстрактный синглтон None).
yurikhan: (Default)

[personal profile] yurikhan 2021-10-08 10:48 am (UTC)(link)

fold-функция должна на пустом списке возвращать нейтральный элемент соответствующей ассоциативной бинарной операции. sum — + — 0, product — * — 1, concat — + — пустая строка, any — or — false, all — and — true, min — meet — +∞ или максимальное представимое значение типа, max — join — −∞ или минимальное представимое значение.

(А если мы не на решётке, то у нас будут проблемы с определением минимума/максимума и на непустых последовательностях.)

yurikhan: (Default)

[personal profile] yurikhan 2021-10-08 01:19 pm (UTC)(link)

Насчёт того, что min должен возвращать type::MIN - возражу

А я этого и не говорил. Наоборот, min({}) = type::MAX, max({}) = type::MIN. Если билетов нет, то оптимальная цена — плюс бесконечность. Если кабачки никто не хочет брать, будем отдавать бесплатно.