Forwarded from Oleg Andreev
Forwarded from dd if=/dev/stuff of=/dev/tg
Очень важная штука: бот для быстрого поиска по базе лекарств с недоказанной эффективность/доказанным вредом. Как человек, который сам ратует за доказательную медицину, считаю такие проекты очень важными.
https://t.iss.one/FufloMedsBot
https://t.iss.one/FufloMedsBot
Telegram
Расстрельный список препаратов
Лекарства, эффективность которых может быть не доказана. Отключен, альтернатива — @Encyclo_bot.
Блог*
#prog #rust А вот тут у нас хороший пример, как, казалось бы, нормальный код может спровоцировать UB. Здесь SPANS — глобальная переменная, вектор внутри RwLock. Чуть позже напишу, в чём проблема, а пока попредлагайте свои варианты
А проблема тут в том, что код для обеспечения корректности работы полагается на
impl Drop for SpanGuard
, который убирает последний вставленный span. О чём при написании unsafe-кода всегда надо помнить — так это о том, что, вообще говоря, нет гарантии, что деструкторы будут вызваны, поэтому полагаться на них для обеспечения memory safety нельзя. Так и тут: если SpanGuard
утекает (а для это достаточно просто вызвать на нём std::mem::forget
), то в глобальном векторе останется ссылка с насильно расширенным временем жизни. Если функция span
была вызвана с ссылкой на локальные данные, то после выхода из этой функции в SPANS
остаётся висячая ссылка, что прямо декларируется как undefined behaviour в Rust.Forwarded from Andrew Demonov
У меня была нагрузка на 15к висящих лонг-пулинг коннектов (кооперативный майнинг-пул средней популярности). Когда логика была на потоках, примерно на 10к коннектах процесс жрал около 40 гигабайт памяти и просто зависал из-за постоянного свопинга. Ну и можно себе представить как охреневал планировщик тред-менеджер. Простое переписывание на асинхронщину снизило потребление памяти раз где-то в 15.
#prog #algo #article
Я раньше не понимал, как работает next_permutation. Теперь, кажется, понимаю.
Next lexicographical permutation algorithm
Я раньше не понимал, как работает next_permutation. Теперь, кажется, понимаю.
Next lexicographical permutation algorithm