Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Бесплатный конструктор сайтов и Landing Page

Хостинг с DDoS защитой от 2.5$ + Бесплатный SSL и Домен

SSD VPS в Нидерландах под различные задачи от 2.6$

✅ Дешевый VPS-хостинг на AMD EPYC: 1vCore, 3GB DDR4, 15GB NVMe всего за €3,50!

🔥 Anti-DDoS защита 12 Тбит/с!

VPS в 21 локации

От 104 рублей в месяц

Безлимитный трафик. Защита от ДДоС.

🔥 VPS до 5.7 ГГц под любые задачи с AntiDDoS в 7 локациях

💸 Гифткод CITFORUM (250р на баланс) и попробуйте уже сейчас!

🛒 Скидка 15% на первый платеж (в течение 24ч)

Использование нитей в Java

Перевод на русский © Сергей Миссан, 2000
Оригинал статьи опубликован на сайте Javable.com

Java Q&A

Может ли программист задать для своего кода использование green threads или native threads?

Нет. Только пользователь может решить, какой пакет поддержки нитей будет использоватся при запуске Java программы. Более того, когда программа запущена, нельзя переключится между green threads и native threads.

Следовательно, вы должны написать код таким образом, чтобы он мог работать как с green threads, так и с native threads. Native threads относительно просты, так как они используют систему управления нитями операционной системы, большинство из которых гарантирует что каждая нить получит возможность работы. Нити с высоким приоритетом запускаются чаще, чем нити с низким, но все они получают возможность работать.

Green threads, однако, не обеспечивают такой гарантии. Если работает нить с высоким приоритетом, цикл в коде, который никогда не выполняет sleep(), yield(), wait() или perform() некоторые блокирующие функции ввода-вывода (I/O) не даст возможности работать другим нитям. Можно только пообещать, что нити с высоким приоритетом будут преобладать над нитями с низким. Это значит, что вся работа по распределению времени лежит на плечах программиста. Следовательно, код, который сам отвечает за распределение времени между нитями будет нормально работать как с green threads, так и с native threads; и, дополнительно, будет хорошо работать с native threads в любой операционной системе.

Брать на себе ответственность за распределение времени в программе кажется трудным, но, на самом деле, для большинства программ нужно сделать не так уж много. Каждый раз, когда нить выполняет сетевую операцию или операцию ввода-вывода, она должна дать возможность работать другой нити.

Распределение времени намного более важно для программ с нитями, которые работают в цикле или тратят значительное время на математические расчеты без ввода-вывода. В этих случаях простой вызов Thread.yield() достаточен для того, чтобы дать возможность работать другим нитям с тем же приоритетом. Для разделения процессорного времени с низко-приоритетными нитями, нить может вызвать Thread.sleep(), или, более точно, wait() для объекта пока нить с низким приоритетом не даст сигнал окончания работы, вызвав notify() для объекта.

Об авторе

Random Walk Computing это наибольшая консалтинговая фирма в Нью Йорке, специализирующаяся на Java/CORBA решениях для предприятий. Известные своим выдающимся знанием Java, консультанты Random Walk публикуются и выступают на самых престижных форумах мира. Для связи с Random Walk используйте javaqa@javaworld.com.

Reprinted with permission from the March 2000 edition of JavaWorld magazine.
Copyright © ITworld.com, Inc., an IDG Communications company.
View the original article at: http://www.javaworld.com/javaworld/javaqa/1999-10/02-qa-native.html

Назад | Содержание | Вперед

 

Скидка до 20% на услуги дата-центра. Аренда серверной стойки. Colocation от 1U!

Миграция в облако #SotelCloud. Виртуальный сервер в облаке. Выбрать конфигурацию на сайте!

Виртуальная АТС для вашего бизнеса. Приветственные бонусы для новых клиентов!

Виртуальные VPS серверы в РФ и ЕС

Dedicated серверы в РФ и ЕС

По промокоду CITFORUM скидка 30% на заказ VPS\VDS

VPS/VDS серверы. 30 локаций на выбор

Серверы VPS/VDS с большим диском

Хорошие условия для реселлеров

4VPS.SU - VPS в 17-ти странах

2Gbit/s безлимит

Современное железо!

Новости мира IT:

Архив новостей

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 7861149
Пресс-релизы — pr@citforum.ru
Обратная связь
Информация для авторов
Rambler's Top100 TopList liveinternet.ru: показано число просмотров за 24 часа, посетителей за 24 часа и за сегодня This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2019 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...