Взаимная блокировка 1 разберись как работает программа

Здравствуйте,Я правильно понимаю,что сначала запускается первая нить,а так как код читается последовательно,сначала запуститься первая нить,затем сработает ошибка,а после запуститься вторая нить? тогда в какой момент произойдет блокировка(deadlock)?

public static void main(String[] args) throws InterruptedException < t1.start(); t1.interrupt() t2.start(); >public static class T1 extends Thread catch (InterruptedException e) < System.out.println(«T1 was interrupted»); >> > public static class T2 extends Thread catch (InterruptedException e) < System.out.println(«T2 was interrupted»); >> > >
Отслеживать
25k 4 4 золотых знака 45 45 серебряных знаков 81 81 бронзовый знак
задан 10 дек 2015 в 22:06
13 2 2 бронзовых знака

1 ответ 1

Сортировка: Сброс на вариант по умолчанию

Ваш код, в том виде, в котором вы его привели, не содержит deadlock’а. (Я предполагаю, что переменные t1 и t2 являются объектами типов T1 и T2 соответственно.)

Пример блокировки в базах данных (deadlock)

Действительно, рассмотрим поток t1 . Он может ожидать только в t2.join(); . Если он остановится там ожидать, то рано или поздно основной поток выполнит (или выполнил раньше) t1.interrupt() , что приведёт к выходу из ожидания, отработке исключения и завершению этого потока.

Теперь, поток t2 . Он может ждать лишь в t1.join(); , на как мы видим, t1 завершается, так что и вызов join() завершится.

Если у вас есть deadlock, он где-то в другом месте.

Источник: ru.stackoverflow.com

36.3. Java – Взаимная блокировка потоков

Взаимная блокировка описывает ситуацию, когда два или более потока блокируются, ожидая друг друга. Взаимная блокировка возникает, когда нескольким потокам нужны одинаковые блокировки, но они получают их в разном порядке. Многопоточная программа Java может пострадать от состояния взаимоблокировки, поскольку ключевое слово synchronized заставляет выполняющийся поток блокироваться в ожидании блокировки или монитора, связанного с указанным объектом. Вот пример.

Пример

public class TestThread < public static Object Lock1 = new Object(); public static Object Lock2 = new Object(); public static void main(String args[]) < ThreadDemo1 T1 = new ThreadDemo1(); ThreadDemo2 T2 = new ThreadDemo2(); T1.start(); T2.start(); >private static class ThreadDemo1 extends Thread < public void run() < synchronized (Lock1) < System.out.println(«Поток 1: Удерживает блокировку 1. «); try < Thread.sleep(10); >catch (InterruptedException e) <> System.out.println(«Поток 1: Ожидает блокировку 2. «); synchronized (Lock2) < System.out.println(«Поток 1: Удерживает блокировку 1 и 2. «); >> > > private static class ThreadDemo2 extends Thread < public void run() < synchronized (Lock2) < System.out.println(«Поток 2: Удерживает блокировку 2. «); try < Thread.sleep(10); >catch (InterruptedException e) <> System.out.println(«Поток 2: Ожидает блокировку 1. «); synchronized (Lock1) < System.out.println(«Поток 2: Удерживает блокировку 1 и 2. «); >> > > >

Когда вы компилируете и выполняете вышеуказанную программу, вы обнаруживаете взаимную блокировку, и получаете следующий вывод программы:

Deadlock Взаимная блокировка | Многопоточное программирование | C++ #8

Читайте также:
Как создать видео в программе movavi


Поток 1: Удерживает блокировку 1 . Поток 2: Удерживает блокировку 2 . Поток 1: Ожидает блокировку 2 . Поток 2: Ожидает блокировку 1 .

Вышеупомянутая программа зависнет навсегда, потому что ни один из потоков не может продолжить и ожидает пока другой поток освободит блокировку, поэтому вы можете выйти из программы, нажав CTRL + C.

Пример решения взаимной блокировки

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

Пример

public class TestThread < public static Object Lock1 = new Object(); public static Object Lock2 = new Object(); public static void main(String args[]) < ThreadDemo1 T1 = new ThreadDemo1(); ThreadDemo2 T2 = new ThreadDemo2(); T1.start(); T2.start(); >private static class ThreadDemo1 extends Thread < public void run() < synchronized (Lock1) < System.out.println(«Поток 1: Удерживает блокировку 1. «); try < Thread.sleep(10); >catch (InterruptedException e) <> System.out.println(«Поток 2: Ожидает блокировку 2. «); synchronized (Lock2) < System.out.println(«Поток 1: Удерживает блокировку 1 и 2. «); >> > > private static class ThreadDemo2 extends Thread < public void run() < synchronized (Lock1) < System.out.println(«Поток 2: Удерживает блокировку 1. «); try < Thread.sleep(10); >catch (InterruptedException e) <> System.out.println(«Поток 2: Ожидает блокировку 2. «); synchronized (Lock2) < System.out.println(«Поток 2: Удерживает блокировку 1 и 2. «); >> > > >

Таким образом, простое изменение порядка блокировок предотвращает взаимную блокировку и завершается со следующим результатом:

Поток 1: Удерживает блокировку 1 . Поток 1: Ожидает блокировку 2 . Поток 1: Удерживает блокировку 1 и 2 . Поток 2: Удерживает блокировку 1 . Поток 2: Ожидает блокировку 2 . Поток 2: Удерживает блокировку 1 и 2 .

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

Оглавление

  • 1. Java – Самоучитель для начинающих
  • 2. Java – Обзор языка
  • 3. Java – Установка и настройка
  • 4. Java – Синтаксис
  • 5. Java – Классы и объекты
  • 6. Java – Конструкторы
  • 7. Java – Типы данных и литералы
  • 8. Java – Типы переменных
  • 9. Java – Модификаторы
  • 10. Java – Операторы
  • 11. Java – Циклы и операторы цикла
  • 11.1. Java – Цикл while
  • 11.2. Java – Цикл for
  • 11.3. Java – Улучшенный цикл for
  • 11.4. Java – Цикл do..while
  • 11.5. Java – Оператор break
  • 11.6. Java – Оператор continue
  • 12. Java – Операторы принятия решений
  • 12.1. Java – Оператор if
  • 12.2. Java – Оператор if..else
  • 12.3. Java – Вложенный оператор if
  • 12.4. Java – Оператор switch..case
  • 12.5. Java – Условный оператор (? 🙂
  • 13. Java – Числа
  • 13.1. Java – Методы byteValue(), shortValue(), intValue(), longValue(), floatValue(), doubleValue()
  • 13.2. Java – Метод compareTo()
  • 13.3. Java – Метод equals()
  • 13.4. Java – Метод valueOf()
  • 13.5. Java – Метод toString()
  • 13.6. Java – Метод parseInt()
  • 13.7. Java – Метод Math.abs()
  • 13.8. Java – Метод Math.ceil()
  • 13.9. Java – Метод Math.floor()
  • 13.10. Java – Метод Math.rint()
  • 13.11. Java – Метод Math.round()
  • 13.12. Java – Метод Math.min()
  • 13.13. Java – Метод Math.max()
  • 13.14. Java – Метод Math.exp()
  • 13.15. Java – Метод Math.log()
  • 13.16. Java – Метод Math.pow()
  • 13.17. Java – Метод Math.sqrt()
  • 13.18. Java – Метод Math.sin()
  • 13.19. Java – Метод Math.cos()
  • 13.20. Java – Метод Math.tan()
  • 13.21. Java – Метод Math.asin()
  • 13.22. Java – Метод Math.acos()
  • 13.23. Java – Метод Math.atan()
  • 13.24. Java – Метод Math.atan2()
  • 13.25. Java – Метод Math.toDegrees()
  • 13.26. Java – Метод Math.toRadians()
  • 13.27. Java – Метод Math.random()
  • 14. Java – Символы
  • 14.1. Java – Метод Character.isLetter()
  • 14.2. Java – Метод Character.isDigit()
  • 14.3. Java – Метод Character.isWhitespace()
  • 14.4. Java – Метод Character.isUpperCase()
  • 14.5. Java – Метод Character.isLowerCase()
  • 14.6. Java – Метод Character.toUpperCase()
  • 14.7. Java – Метод Character.toLowerCase()
  • 14.8. Java – Метод Character.toString()
  • 15. Java – Строки
  • 15.1. Java – Метод charAt()
  • 15.2. Java – Метод compareTo()
  • 15.3. Java – Метод compareToIgnoreCase()
  • 15.4. Java – Метод concat()
  • 15.5. Java – Метод contentEquals()
  • 15.6. Java – Метод copyValueOf()
  • 15.7. Java – Метод endsWith()
  • 15.8. Java – Метод equals()
  • 15.9. Java – Метод equalsIgnoreCase()
  • 15.10. Java – Метод getBytes()
  • 15.11. Java – Метод getChars()
  • 15.12. Java – Метод hashCode()
  • 15.13. Java – Метод indexOf()
  • 15.14. Java – Метод intern()
  • 15.15. Java – Метод lastIndexOf()
  • 15.16. Java – Метод length()
  • 15.17. Java – Метод matches()
  • 15.18. Java – Метод regionMatches()
  • 15.19. Java – Метод replace()
  • 15.20. Java – Метод replaceAll()
  • 15.21. Java – Метод replaceFirst()
  • 15.22. Java – Метод split()
  • 15.23. Java – Метод startsWith()
  • 15.24. Java – Метод subSequence()
  • 15.25. Java – Метод substring()
  • 15.26. Java – Метод toCharArray()
  • 15.27. Java – Метод toLowerCase()
  • 15.28. Java – Метод toString()
  • 15.29. Java – Метод toUpperCase()
  • 15.30. Java – Метод trim()
  • 15.31. Java – Метод valueOf()
  • 15.32. Java – Классы StringBuilder и StringBuffer
  • 15.32.1. Java – Метод append()
  • 15.32.2. Java – Метод reverse()
  • 15.32.3. Java – Метод delete()
  • 15.32.4. Java – Метод insert()
  • 15.32.5. Java – Метод replace()
  • 16. Java – Массивы
  • 17. Java – Дата и время
  • 18. Java – Регулярные выражения
  • 19. Java – Методы
  • 20. Java – Потоки ввода/вывода, файлы и каталоги
  • 20.1. Java – Класс ByteArrayInputStream
  • 20.2. Java – Класс DataInputStream
  • 20.3. Java – Класс ByteArrayOutputStream
  • 20.4. Java – Класс DataOutputStream
  • 20.5. Java – Класс File
  • 20.6. Java – Класс FileReader
  • 20.7. Java – Класс FileWriter
  • 21. Java – Исключения
  • 21.1. Java – Встроенные исключения
  • 22. Java – Вложенные и внутренние классы
  • 23. Java – Наследование
  • 24. Java – Переопределение
  • 25. Java – Полиморфизм
  • 26. Java – Абстракция
  • 27. Java – Инкапсуляция
  • 28. Java – Интерфейсы
  • 29. Java – Пакеты
  • 30. Java – Структуры данных
  • 30.1. Java – Интерфейс Enumeration
  • 30.2. Java – Класс BitSet
  • 30.3. Java – Класс Vector
  • 30.4. Java – Класс Stack
  • 30.5. Java – Класс Dictionary
  • 30.6. Java – Класс Hashtable
  • 30.7. Java – Класс Properties
  • 31. Java – Коллекции
  • 31.1. Java – Интерфейс Collection
  • 31.2. Java – Интерфейс List
  • 31.3. Java – Интерфейс Set
  • 31.4. Java – Интерфейс SortedSet
  • 31.5. Java – Интерфейс Map
  • 31.6. Java – Интерфейс Map.Entry
  • 31.7. Java – Интерфейс SortedMap
  • 31.8. Java – Класс LinkedList
  • 31.9. Java – Класс ArrayList
  • 31.10. Java – Класс HashSet
  • 31.11. Java – Класс LinkedHashSet
  • 31.12. Java – Класс TreeSet
  • 31.13. Java – Класс HashMap
  • 31.14. Java – Класс TreeMap
  • 31.15. Java – Класс WeakHashMap
  • 31.16. Java – Класс LinkedHashMap
  • 31.17. Java – Класс IdentityHashMap
  • 31.18. Java – Алгоритмы Collection
  • 31.19. Java – Iterator и ListIterator
  • 31.20. Java – Comparator
  • 32. Java – Дженерики
  • 33. Java – Сериализация
  • 34. Java – Сеть
  • 34.1. Java – Обработка URL
  • 35. Java – Отправка Email
  • 36. Java – Многопоточность
  • 36.1. Java – Синхронизация потоков
  • 36.2. Java – Межпоточная связь
  • 36.3. Java – Взаимная блокировка потоков
  • 36.4. Java – Управление потоками
  • 37. Java – Основы работы с апплетами
  • 38. Java – Javadoc
Читайте также:
Как пользоваться программой алгоритм

Источник: proglang.su

Untitled

Guest User

Not a member of Pastebin yet? Sign Up, it unlocks many cool features!

text 1.24 KB | None | 0 0

package com.javarush.task.task16.task1625;

Взаимная блокировка

1. Разберись, как работает программа.

2. Не меняя классы T1 и T2 сделай так, чтобы их нити завершились, не обязательно успешно.

3. Метод sleep не использовать.

public class Solution <

static Thread t1 = new T1();

static Thread t2 = new T2();

public static void main(String[] args) throws InterruptedException <

t1.interrupt();

t2.interrupt();

public static class T1 extends Thread <

public void run() <

System.out.println(«T1 finished»);

> catch (InterruptedException e) <

System.out.println(«T1 was interrupted»);

public static class T2 extends Thread <

public void run() <

System.out.println(«T2 finished»);

> catch (InterruptedException e) <

System.out.println(«T2 was interrupted»);

Advertisement

Add Comment

Please, Sign In to add comment

Advertisement

GetText | 6 min ago | 0.29 KB

HTML | 10 min ago | 2.57 KB

HTML | 22 min ago | 2.42 KB

Lua | 45 min ago | 6.77 KB

HTML | 57 min ago | 82.11 KB

HTML | 58 min ago | 5.95 KB

Motorola 68000 HiSoft Dev | 1 hour ago | 21.77 KB

C# | 1 hour ago | 3.39 KB

Advertisement

We use cookies for various purposes including analytics. By continuing to use Pastebin, you agree to our use of cookies as described in the Cookies Policy. OK, I Understand

Not a member of Pastebin yet?
Sign Up, it unlocks many cool features!

Источник: pastebin.com

Рейтинг
( Пока оценок нет )
Загрузка ...
EFT-Soft.ru