Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
 Аватар для Spickard
7 / 7 / 0
Регистрация: 07.04.2011
Сообщений: 25

Задача на многопоточность в Java

28.05.2016, 22:51. Показов 1829. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть задача, которая звучит примерно следующим образом:
Есть класс SomeObjectHandler, который передаёт обработку объекта сторонней системе (см. код далее). SomeObject класс с корректно определёнными методами equals и hashCode. Метод может быть вызван многими потоками (для примера пусть будет 10). Сторонняя система хорошо работает одновременно, если SomeObject разные, но ломается, если SomeObject одинаковые. Необходимо создать свою имплeментацию метода handle так, чтобы не было одновременной обработки одинаковых SomeObject. Однако все они должны быть обработаны рано или поздно.
Java
1
2
3
4
5
6
7
8
9
public class SomeObjectHandler{
 
    private OutSystem outSystem;
 
    public void handle(SomeObject someObject ) {
        outSystem.process(someObject );
    }
 
}
Я думал над тем, чтобы использовать, например блокирующую очередь, но смущает необходимость заранее задавать размер буфера.

Помогите, пожалуйста, в поиске направления для написания решения.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.05.2016, 22:51
Ответы с готовыми решениями:

Многопоточность в java
Добрый день. Появился вопрос по многопоточности: Есть 3 класса: public class main { public static void main(String args) { ...

Многопоточность Java
Помогите с заданием. В текстовом файле записаны слова (для простоты – в каждой строке одно слово). Из файла данные читаются тремя...

Многопоточность (Multithreading) в Java
Помогите пожалуйста разобраться с Multithreading в Java,а точнее с управлением потоков. Передо мной стоит такая задача ,у меня есть 5...

4
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
28.05.2016, 23:31
Первое, что пришло в голову:
Java
1
2
3
4
5
6
7
8
9
10
public class SomeObjectHandler {
 
    private OutSystem outSystem;
 
    public void handle(SomeObject someObject ) {
        synchronized(someObject) {
            outSystem.process(someObject );
        }
    }
}
На сколько я понимаю, данный код будет лочить выполнение OutSystem :: process при одновременном вызове с одним и тем же объектом, пропуская различные копии:
Code
1
2
obj1 == obj2 -> lock
obj1 != obj2 -> run// obj1.equlas(obj2) так же пропустит
Но, честно говоря, я не уверен.
1
 Аватар для Spickard
7 / 7 / 0
Регистрация: 07.04.2011
Сообщений: 25
28.05.2016, 23:35  [ТС]
Я вот подумал над одним моментом:
А при указанном вами способе разве лок будет работать при разных объектах (созданных разными new, т.е. ссылки будут разными), даже если хешкод и иквалс скажут что они равны?
0
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
28.05.2016, 23:51
Цитата Сообщение от Spickard Посмотреть сообщение
созданных разными new
не сработает, тк у каждого объекта будет свой собственный lock

Добавлено через 2 минуты
Сработает только если ссылки будут на один и тот же объект
1
 Аватар для Spickard
7 / 7 / 0
Регистрация: 07.04.2011
Сообщений: 25
29.05.2016, 19:39  [ТС]
Жаль, а нужно чтобы они по иквалс блокировались бы в идеале.
Думаю над тем, чтобы использовать кольцевой буфер, например ArrayBlockingQueue с запоминанием последнего отправленного ключа. Если ключ уже был, класть в очередь, а её потом пытаться обходить.
Но это как-то сложно звучит + неизвестно какой размер под буфер выделять.

Добавлено через 19 часов 43 минуты
Пытаюсь сделать примерно так:
Java
1
2
3
4
5
6
7
8
9
10
11
12
private OutSystem outSystem = new OutSystem ();
 
    private ConcurrentHashMap<Key, ReentrantLock> locksMap = new ConcurrentHashMap<Key, ReentrantLock>();
 
    public void handle(Key key) {
        locksMap.putIfAbsent(key, new ReentrantLock());
        ReentrantLock lock = locksMap.get(key);
        lock.lock();
        outSystem .process(key);
        locksMap.remove(key);
        lock.unlock();
    }
Но, как мне кажется, у такого варианта проблемы с атомарностью. Можно ли как-то написать оптимальнее?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.05.2016, 19:39
Помогаю со студенческими работами здесь

Многопоточность. Java. Блокировка
Здравствуйте! Задание такое: есть автобусы(потоки), есть остановки, максимальное количество автобусов на остановке 2, если на остановке два...

Многопоточность. Калькулятор. Java
Всем Привет. В теории я ознакомлен с многопоточностью, но не могу ее применить в практике. Прошу подскажите на примере как реализовать...

Многопоточность Java (Взаимная блокировка)
Есть пример public class Student { private ArrayList friends = new ArrayList(); public synchronized ArrayList getFriends() ...

Многопоточность и запуск сторонних программ из Java
Привет. Не много предыстории. Есть много скриптов (poershell, sql, пара внутренних программ) которые запускаются одним общим батником....

Многопоточность, задача:
У нас есть два параметра типа int i String и допустим три потока (один главный и остальные дочерные, но если правильно создать класс, то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru