Многопоточное программирование в Java
Қосымшада ыңғайлырақҚосымшаны жүктеуге арналған QRRuStore · Samsung Galaxy Store
Huawei AppGallery · Xiaomi GetApps

автордың кітабынан сөз тіркестері  Многопоточное программирование в Java

Анна Курдина
Анна Курдинадәйексөз келтірді2 жыл бұрын
При этом ускорение программы с помощью многопоточных вычислений на нескольких процессорах ограничено размером последовательной части программы. Это так называемый закон Амдала. Этот закон гласит следующее — В случае, когда задача разделяется на несколько частей, суммарное время её выполнения на параллельной системе не может быть меньше времени выполнения самого длинного фрагмента. Согласно этому закону, ускорение выполнения программы за счёт распараллеливания её инструкций на множестве вычислителей, ограничено временем, необходимым для выполнения её последовательных инструкций.
1 Ұнайды
Комментарий жазу
Анна Курдина
Анна Курдинадәйексөз келтірді2 жыл бұрын
ускорение программы с помощью многопоточных вычислений на нескольких процессорах ограничено размером последовательной части программы. Это так называемый закон Амдала.
1 Ұнайды
Комментарий жазу
Когда один поток заходит внутрь блока кода, помеченного словом synchronized, то Java-машина тут же блокирует монитор объекта, который указан в круглых скобках после слова synchronized.
Комментарий жазу
Еще раз, если два нестатических метода класса объявлены как synchronized, то в каждый момент времени из разных потоков на одном объекте может быть вызван только один из них.
Комментарий жазу
Конструкторы не могут быть синхронизированы
Комментарий жазу
Таким образом, доступ к синхронизированным статическим полям класса контролируется блокировкой, отличной от блокировки для любого экземпляра класса. Поэтому статические синхронизированные методы и нестатические синхронизированные методы никогда не заблокируют друг друга.
Комментарий жазу
Когда вызывается статический синхронизированный метод, так как статический метод связан с классом, а не с объектом, в этом случае поток получает блокировку для объекта Class, связанного с классом и представляющего класс в среде выполнения.
Комментарий жазу
Синхронизация потоков Теперь, когда мы рассмотрели потоки, давайте разберем ключевую концепцию в многопоточном программировании, которая идет рука об руку с потоками, и это блокировки. Потоки взаимодействуют между собой, главным образом, путем совместного доступа к полям объектов. Это взаимодействие делает возможными два вида ошибок: интерференция потоков и ошибки согласованности памяти. Предположим, что у нас есть очень простой метод объекта, который принимает число и увеличивает его на единицу. Другой метод этого объекта уменьшает это число на единицу. Предположим, есть два потока T1 и T2, и один поток хочет увеличить число, а другой поток хочет уменьшить число. Эти два потока могут быть запланированы на двух разных ядрах, и они могут читать и записывать поле объекта в одно и то же время, и результат будет непредсказуемым. При одновременной записи возникнет интерференция потоков. А при одновременной записи и чтении возникнет ошибка согласованности памяти. Как нам избежать ситуации, когда два потока хотят получить доступ к одному и тому же объекту одновременно? Для этого используется блокировка. Java обеспечивает блокировки для защиты определенных частей кода, которые будут выполняться несколькими потоками одновременно. Самый простой способ блокировки определенного метода — это определить метод с ключевым словом synchronized. Ключевое слово synchronized в Java обеспечивает: Что только один поток может одновременно выполнять блок кода Что каждый поток, входящий в синхронизированный блок кода, видит результаты всех предыдущих модификаций, которые были защищены одной и той же блокировкой. Синхронизация необходима для взаимоисключающего доступа к блокам и для надежной связи между потоками. Синхронизация метода обеспечивает, что, когда один поток выполняет синхронизированный метод объекта, все другие потоки, которые вызывают синхронизированные методы этого объекта приостанавливают выполнение до тех пор, пока первый поток не закончит свою работу с объектом. Когда синхронизированный метод завершится, он автоматически установит причинно-следственную связь для последующего вызова синхронизированного метода этого объекта. Это гарантирует, что изменения состояния объекта будут видны для всех потоков. Когда поток вызывает синхронизированный метод, он автоматически получает внутреннюю блокировку для объекта этого метода и освобождает его при возврате метода. Освобождение блокировки происходит, даже если возврат метода был вызван неперехваченным исключением. Другими словами, каждый объект в Java имеет ассоциированный с ним монитор. Монитор представляет своего рода инструмент для управления доступа к объекту.
Комментарий жазу
Синхронизация метода обеспечивает, что, когда один поток выполняет синхронизированный метод объекта, все другие потоки, которые вызывают синхронизированные методы этого объекта приостанавливают выполнение до тех пор, пока первый поток не закончит свою работу с объектом.
Комментарий жазу
Ключевое слово synchronized в Java обеспечивает: Что только один поток может одновременно выполнять блок кода
Комментарий жазу