Виртуальные потоки в Java

Поделиться
HTML-код
  • Опубликовано: 4 янв 2025

Комментарии • 75

  • @aleksandrplatonov2145
    @aleksandrplatonov2145 10 месяцев назад +2

    Очень внятно и четко. До Вас читал статьи, но общий смысл за терминологией ускользал. Евгений, спасибо )

  • @AlexSmile-y2x
    @AlexSmile-y2x 10 месяцев назад +5

    Круто расскажал, Жень! Надо было еще сравнение с работой на NIO селекторах привести, там тоже альтернативный подход к неблокирующей обработке

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Это уже будут не основы :)
      Спасибо за комментарий!

  • @friedbearsburninhell2022
    @friedbearsburninhell2022 10 месяцев назад +4

    Хороший контент - многим может быть актуален =)

  • @ktotam8913
    @ktotam8913 10 месяцев назад +3

    Евгений, спасибо за подсказку, когда на джуна пойду на собеседование, так же скажу в начале:
    Все сказанное мною в данном интервью является оценочным суждением 😂

  • @tiy2000
    @tiy2000 10 месяцев назад +1

    Очень интересно!
    Спасибо!)

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Спасибо за комментарий!

  • @johndow1591
    @johndow1591 9 месяцев назад

    Очень доступно. Спасибо!

  • @Batyrbala
    @Batyrbala 9 месяцев назад

    Как всегда на высоте, сенсей❤

  • @Valerikvv80
    @Valerikvv80 10 месяцев назад

    Отличный ролик. Спасибо

  • @ensolol
    @ensolol 10 месяцев назад

    Евгений, благодарю! Крепко жму руку!)

  • @LAZIO14
    @LAZIO14 10 месяцев назад

    Лайк заочно. А видос гляну чуть позже) Спасибо!

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Спасибо за поддержку!

  • @telpozis
    @telpozis 10 месяцев назад

    Спасибо, Евгений! =) Но тут очень важно, что "контекст сохраняемый в хип" должен быть относительно не большого размера. Тут сложно сказать конкретные цифры, т.к. железо сервера + ОС + ПО + размер контекста = дают просто огромное количество вариантов :) Тема классная, надо больше практики :)

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Спасибо за отзыв!
      Да, много факторов, цифра взята крайне условно, "с потолка".

  • @Pablo-m8m5b
    @Pablo-m8m5b 10 месяцев назад

    Большое спасибо.

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за комментарий!

  • @dmitryischenko831
    @dmitryischenko831 10 месяцев назад

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

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за отзыв!
      Поправлю формат, спасибо.

  • @elnar_1206
    @elnar_1206 10 месяцев назад

    Спасибо за видео 🔥🔥🔥

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за комментарий!

  • @ercefwxdx
    @ercefwxdx 10 месяцев назад

    Дякую за відео, дуже круто!

  • @myNextPrediction
    @myNextPrediction 10 месяцев назад

    Жостко. Як завжди нічо не зрозуміло з першого разу, буду переглядати відео поки не дійде🐺

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за комментарий :)

  • @maksimus.ssirotkin1124
    @maksimus.ssirotkin1124 10 месяцев назад +2

    а может ли быть , абстракция над ядром и потоком ядра? и за счет чего получается легковесность потока? Есть ли разница подобных языковых фреймворков в Java Go or Kotlin, т/е если по простому в ходе выполнения нескольких задач, когда раньше поток на одном ядре блокировал ядро, сейчас передает другому потоку на этом ядре или другом ядре. Но возможно это видео надо еще пересмотреть.

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Спасибо за вопрос:
      Легковесность потока достигается в Java, в основном, за счет того, что каждый виртуальный поток не обязательно привязан к потоку ядра операционной системы.
      По поводу Go и Kotlin - да, есть goroutines и coroutines, но работают несколько по-другому.

    • @C8Z0T7Q6706199120089
      @C8Z0T7Q6706199120089 Месяц назад

      А как логировать сквозной процесс если из кучи на другой воркер из хипа данные попадут?

  • @Steklopod
    @Steklopod 8 месяцев назад

    Четко 👍🏻

  • @JohnJohn31595
    @JohnJohn31595 10 месяцев назад

    it's good! Thank you!

  • @Cassin1797
    @Cassin1797 10 месяцев назад

    Привет! Спасибо за видео! Вопрос немного не по теме, но что случилось с публичным менторингом Игоря? Планируются ли еще в будущем видео по менторингу формата advanced?

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за отзыв!
      Игорь устроился на работу и не смог совмещать с обучением. В будущем - планируется, сейчас «обкатываю» новую программу, по которой будем работать в рамках блока «Advanced».

  • @non_holy6286
    @non_holy6286 4 месяца назад

    Здравствуйте! Подскажите, пожалуйста, вы еще работаете с менти? Как получить информацию по этой части?

    • @EugeneSuleimanov
      @EugeneSuleimanov  4 месяца назад

      @@non_holy6286 здравствуйте! Да, работаю. Телеграмм: @proselyte

  • @ГлебВалерьевич-у6ы
    @ГлебВалерьевич-у6ы 10 месяцев назад

    ай что за красавчик в кадре

  • @errodion
    @errodion 10 месяцев назад

    Как же он хорош

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Спасибо за комментарий!

  • @Alexander-mj3jk
    @Alexander-mj3jk 7 месяцев назад

    для любителей использовать котлин что-то поменяется?

    • @EugeneSuleimanov
      @EugeneSuleimanov  7 месяцев назад +1

      Нет, любовь к котлину не исчезнет :)

    • @Alexander-mj3jk
      @Alexander-mj3jk 7 месяцев назад

      @@EugeneSuleimanov посмотрел елизарова, сравнение виртуальных потоков и котлин корутин. Виртуальные потоки - это более глобальная концепция, она жрет (на момент того видео - год назад) раза в полтора-два больше памяти, и лучше подходит если старый тормозной многопоточный код надо улучшить. Для некоторых это важно. А вот так навскидку, если делать новое что-то, то мне котлин-корутины нравятся больше. Единственное что у них плохо - в них недонаписаны некоторые примитивы синхронизации. Например нету честного-нечестного ReadWriteLock (где-то есть тикет в котором Елизаров обещал, что когда будет время и желание - сделает). Мне правда этот ReadWriteLock вообще ни разу не был нужен.

  • @Max-wn2gd
    @Max-wn2gd 10 месяцев назад

    большое спасибо. очень интересно. А ссылка на репозиторий не рабочая(

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Большое спасибо за отзыв!
      По ссылке - поправил - уже рабочая.

  • @ivanknyazev7878
    @ivanknyazev7878 10 месяцев назад

    Оу, а что ExecutorService теперь автоклозабл реализует?

    • @EugeneSuleimanov
      @EugeneSuleimanov  9 месяцев назад

      Да, в новых версиях это есть.

  • @amalnishanaliev3142
    @amalnishanaliev3142 10 месяцев назад

    На правах члена клуба "Покажи свою некомпетентность", хочу задать вопрос. Правильно я понимаю, что в java 21 garbage collector научили работать с контекстом виртуальных потоков?

    • @EugeneSuleimanov
      @EugeneSuleimanov  9 месяцев назад

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

  • @SeusAmibius
    @SeusAmibius 10 месяцев назад

    "Пишу код" и "Говорю слова" это как я понял интерфейсы человеческие) А что тогда "> 10 лет опыта в разработке" на абстрактный класс вроде не похоже, паттерн?

  • @vladikshk
    @vladikshk 10 месяцев назад

    Ссылка на репозиторий не рабочая

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +2

      Спасибо за сигнал - исправил.

  • @nurakhmetzunun5802
    @nurakhmetzunun5802 10 месяцев назад

    kotlin coroutine теперь в java)

  • @michael200kg
    @michael200kg 10 месяцев назад

    Если использовать stealing pool то потоки не будут простаивать, как только поток освободится он "стащит" задачу у другого потока.

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Все верно, здесь этот момент проговаривается, мы хотим эмулировать ситуацию, когда на каждый запрос идет отдельный поток (аналог API).

  • @favoritdmitry6786
    @favoritdmitry6786 10 месяцев назад

    Для чего нужно иметь механизм планирования потоками в процессе ОС ещё и планировщик в виртуальной машине...

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      Как минимум гибкость и управление внутренними ресурсами. Для ОС JVM простая программа наравне с остальными...

    • @favoritdmitry6786
      @favoritdmitry6786 10 месяцев назад

      @@EugeneSuleimanov так или иначе виртуальная машина использует механизм ОС, каждой ОС..

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад

      @@favoritdmitry6786 верно. А в чем противоречие?

  • @MrRomanvideo
    @MrRomanvideo 4 месяца назад

    Если уж говоришь 'точка остановы', то иди дальше и говори 'противожук'. ;)

    • @EugeneSuleimanov
      @EugeneSuleimanov  3 месяца назад +1

      @@MrRomanvideo я остановлюсь на отладчике ))

    • @MrRomanvideo
      @MrRomanvideo 3 месяца назад

      @@EugeneSuleimanov а, так да 👍)

  • @МаксимЖивотовский-ц8о
    @МаксимЖивотовский-ц8о 10 месяцев назад

    +

    • @EugeneSuleimanov
      @EugeneSuleimanov  10 месяцев назад +1

      Спасибо за поддержку!