Danh mục

Lập trình Java cơ bản : Multithreading part 5

Số trang: 5      Loại file: pdf      Dung lượng: 68.94 KB      Lượt xem: 7      Lượt tải: 0    
Hoai.2512

Phí lưu trữ: miễn phí Tải xuống file đầy đủ (5 trang) 0
Xem trước 2 trang đầu tiên của tài liệu này:

Thông tin tài liệu:

Đồng bộ hoá tuyến• Việc các tuyến trong chương trình cùng truy nhập vào một đối tượng có thể sẽ đem lại kết quả không như mong muốn. Ví dụ: Tuyến A cập nhật đối tượng X và tuyến B đọc dữ liệu từ X. Rất có thể xảy ra sự cố là tuyến B đọc dữ liệu chưa được cập nhật. • Đồng bộ hoá tuyến (thread synchronization) giúp cho tại mỗi thời điểm chỉ có một tuyến có thể truy nhập vào đối tượng còn các tuyến khác phải đợi. Ví dụ: Trong khi tuyến A cập nhật...
Nội dung trích xuất từ tài liệu:
Lập trình Java cơ bản : Multithreading part 5Vòng đời của tuyến bor n st art r ead y q u ant um d isp a t c h e xp ir a t io n I/ O (a ssig n a yield Al l co p ro c e sso r) in te rru p t or n t ify m fy p le ru nn in g ot i no ti o issu n e I/ O re co it qu wa m p e st ee pl et sl e wa it in g slee p ing de a d bloc ke d slee p in te rv al e xpire s 21Đồng bộ hoá tuyến• Việc các tuyến trong chương trình cùng truy nhập vào một đối tượng có thể sẽ đem lại kết quả không như mong muốn. Ví dụ: Tuyến A cập nhật đối tượng X và tuyến B đọc dữ liệu từ X. Rất có thể xảy ra sự cố là tuyến B đọc dữ liệu chưa được cập nhật.• Đồng bộ hoá tuyến (thread synchronization) giúp cho tại mỗi thời điểm chỉ có một tuyến có thể truy nhập vào đối tượng còn các tuyến khác phải đợi. Ví dụ: Trong khi tuyến A cập nhật X thì tuyến B chưa được đọc. 22Đồng bộ hoá tuyến• Dùng từ khoá synchronized trên các phương thức để thực hiện đồng bộ hoá.• Đối tượng khai báo phương thức synchronized sẽ có một bộ giám sát (monitor). Bộ giám sát đảm bảo tại mỗi thời điểm chỉ có một tuyến được gọi phương thức synchronized.• Khi một tuyến gọi phương thức synchronized, đối tượng sẽ bị khoá. Khi tuyến đó thực hiện xong phương thức, đối tượng sẽ được mở khoá. 23Đồng bộ hoá Thread• Trong khi thực thi phương thức synchronized, một tuyến có thể gọi wait() để chuyển sang trạng thái chờ cho đến khi một điều kiện nào đó xảy ra. Khi tuyến đang chờ, đối tượng sẽ không bị khoá.• Khi thực hiện xong công việc trên đối tượng, một tuyến cũng có thể thông báo (notify) cho các tuyến khác đang chờ để truy nhập đối tượng.• Deadlock: Tuyến A chờ tuyến B và tuyến B cũng chờ tuyến A. 24Quan hệ Producer-Consumer• Giả sử có 2 tuyến: Producer ghi dữ liệu vào một buffer và Consumer đọc dữ liệu từ buffer => Cần có sự đồng bộ hoá nếu không dữ liệu có thể bị Producer ghi đè trước khi Consumer đọc được hoặc Consumer có thể đọc một dữ liệu nhiều lần khi Producer chưa sản xuất kịp. đọc gh i buffer Consumer Producer 25 ...

Tài liệu được xem nhiều: