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

В Kotlin классу недостаточно имплементировать Runnable, чтобы экземпляры этого класса

могли работать отдельным потоком? Только Thread наследовать?

21 ответов

16 просмотров

Как и в java. Тебе нужен поток, на котором запускать ранаблы. Ранаблы - это чисто контейнеры задач, в них нет магии, их отдают потокам или екзекьюторам

L D- Автор вопроса

В Java когда имплементируешь Runnable, экземпляр класса можно запустить через start, и содержимое метода run будет запускаться в отдельном потоке. В котлин имплементация Runnable ничего не даёт

Ничего подобного в жава нет) Отработает в том потоке, в котором вызовеешь

L D- Автор вопроса

А на сайтах с уроками многопоточности напрямую пишут, что это альтернативный метод создания потока и более того, если вызвать в экземплярее класса имплементирующего Runnable в Java, вывод информации о потоке, то ясно становится, что это отдельный поток. В Kotlin эта же информация даёт понять, что это основной поток

Булщит. Либо плохой туториал, либо ты немного неверно понял

Либо сайты плохие, либо ты что-то не так понимаешь

У тебя раннабл - это интерфейс. Напиши простой ранабл, где выведешь в консоль Thread.currentThread(), и тупо вызови в дефолтной потоке run

L D- Автор вопроса

Возможно туториал..

L D- Автор вопроса

Но сейчас сам проверю

Описано херово таки. Читай дальше: ты передаешь ранабл потоку

"Другой способ определения потока". Первый - наследование от потока и переопределение run(), второй - создание потока из Runnable объекта

L D- Автор вопроса

Да, это я видел. Runnable - это как часть потока, а не другой способ его создания

Не совсем. Ранабл - чисто отдельная сущность для описания "единицы работы", я бы сказал. И да, поток реализует ранабл

Берешь в гугле типовой фрагмент джава кода в 10 строк где какая то фигня отправляется на исполнение в отд.поток, копируешь его в котлин проект и смотришь

L D- Автор вопроса

Разобрался, спасибо. В котлине есть альтернативы способа синхронизации потоков наподобие Exchanger в Java? Понимаю, что и в котлине его можно использовать, но мб как и корутины есть что-то более оптимальное

Корутины не "оптимальнее", корутины написаны поверх все тех же java.cocnurrency. У котлина своей многопоточки нет, так что брать жавовскую вполне нормально

L D- Автор вопроса

А при использовании корутин обмен данными между потоками возможен? Смотрю, многие предпочитают именно корутины использовать

Ты с потоками разберись сначала, корутины в разы сложнее для понимания + те же проблемы многопоточки могу возникать в корутинах, если корутины из разных потоков выполняются

L D- Автор вопроса

Я в Java уже использовал Exchanger, в котлине пытаюсь его же использовать возникают проблемы, потому и спрашиваю

То есть корутины легче будет понимать, когда потоки прохаваешь. Все штуки для многопоточности жавы можно точно так же в котлине использовать

Скорее всего используешь некорректно, разницы между языками тут нет

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта