172 похожих чатов

Может кто-нибудь подсказать ответ на заданный вопрос? С растом на

вы, боюсь тоже ошибиться при работе

8 ответов

6 просмотров

лучше в @rust_async спросить напрямую

Сергей
лучше в @rust_async спросить напрямую

Тут для всего есть отдельный чат?

OnError GoTo Error
Тут для всего есть отдельный чат?

все чаты перечислены в закрепе

Ну, если мы говорим про простые юнит-тесты, то это tokio::test. А если мы говорим про edge-cases, в которых можно поймать багу, то тут всё очень сложно. Самый простой способ не поймать баг — не использовать то, что может багнуться. Забудь про селекты, и дроп хендлов на футуры в экзекуторе. Прочитай https://vorpus.org/blog/notes-on-structured-concurrency-or-go-statement-considered-harmful/ Пиши код так, чтобы он выглядел как "structured concurrency". (К слову, для обычных тредов может быть полезно прочитать статью Кладова на эту тему: https://matklad.github.io/2019/08/23/join-your-threads.html) В общем, изучаешь best-practices и читаешь async vision, чтобы знать, где у асинка дыры. Проверять async код — это как проверять программы с goto; проще всего их проверять, когда у тебя нет ни одного goto в коде.

n- Автор вопроса
Эрик
Ну, если мы говорим про простые юнит-тесты, то это...

Общая идея-то мне понятна (с прерыванием потока исполнения) Пересмотрел пример и теперь не понимаю в чем там ошибка? Вот код async fn parse_line(socket: &TcpStream) -> Result<String, Error> { let len = socket.read_u32().await?; (1) let mut line = vec![0; len]; socket.read_exact(&mut line).await?; (2) let line = str::from_utf8(line)?; Ok(line) } В (2) считается же тот объём данных, что был доступен в (1), почему разрыв в строке получается? Много данных за раз считывается?

n
Общая идея-то мне понятна (с прерыванием потока ис...

Видимо, с какого-то перепугу авейт на 2 пендится, с размером принимаемых данных как-то связано раз. Мол, где-то ещё есть ссылка на сокет, которая читает из tcpstream. Так предположил.

Traveller Kolsky
Видимо, с какого-то перепугу авейт на 2 пендится, ...

Нет, ты тоже не в ту сторону смотришь. У нас код выглядит как обычный растовый код, но на самом деле на любой await надо смотреть как на херню, у которой внутри panic при кенселе вызывается, а на любой селект надо смотреть как на catch_unwind, который ловит эти паники после кенсела.

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

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

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
#include <stdio.h> int main(void) { int n; scanf("%d", &n); int digits1[n] = {0}; int digits2[n] = {0}; я не могу таким образом заранее массив нулями заполнить?
Linus
12
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
я про форму записи. смысл указывать что 8 байтный регистр 8 байт?
Aiwan \ (•◡•) / _bot
10
читать файл максимально быстро? странный вопрос))
zamtmn
53
Вроде бы вопрос уже заезжанный, но тем не менее У меня есть функция menu() которая выводит набор возможных действий, а затем спрашивает у пользователя что он хотел бы сделать....
David Golovatin
2
Кто создает тут ботов для телеграмм групп ?
Antskup
8
а как бы вылезти из ИО, что то типа IO -> Ether или в какую сторону смотреть ? что то туплю
Fedor
14
Карта сайта