Các giải pháp đồng bộ hóa

7 1.4K 9
Các giải pháp đồng bộ hóa

Đang tải... (xem toàn văn)

Thông tin tài liệu

Các giải pháp đồng bộ hóa

1BÀI 5 : CÁC GIẢI PHÁP ĐỒNG BỘ HOÁNhóm giải pháp Busy Waiting Sử dụng các biến cờ hiệuSử dụng việc kiểm tra luân phiên Giải pháp của Peterson Cấm ngắtChỉ thò TSL Nhóm giải pháp  Sleep & Wakeup SemaphoreMonitorMessage 2Các giải pháp “Busy waiting”While (chưa có quyền) donothing() ;CS;Từ bỏ quyền sử dụng CS Tiếp tục tiêu thụ CPU trong khi chờ đợi vào miền găng Không đòi hỏi sự trợ giúp của Hệ điều hành 3Các giải pháp “Sleep & Wake up”if (chưa có quyền) Sleep() ; CS;Wakeup( somebody); Từ bỏ CPU khi chưa được vào miền găng Cần được Hệ điều hành hỗ trợ 4Semaphore Được hỗ trợ bởi HĐH Tổ chức độc quyền truy xuất Semaphore s; // s >=0Down (s) & Up(s)Down (s)CS; Up(s) Tổ chức “hò hẹn”P1 :Job1; Up(s)P2:Down (s);Job2; 5Monitor Được hỗ trợ bởi NNLT Bảo đảm độc quyền truy xuất tự động Sử dụng biến điều kiện để thực hiện “Hò hẹn” Monitor mint x;Condition c;Function F1(){ ….wait(c); …}Function F2(){ ….signal(c); …} 6Message Được hỗ trợ bởi HĐH Đồng bộ hóa trên môi trường phân tánServer P 1. Send Request2. Receive Accept3. Send Finish 7Các bài toán đồng bộ hoá kinh điểnProducer-Consumer P không được ghi dữ liệu vào buffer đã đầyC không được đọc dữ liệu từ buffer đang trốngP và C không được thao tác trên buffer cùng lúc PCBuffer (N)Readers - Writers W không được cập nhật dữ liệu khi có một R đang truy xuất CSDL .  Tại một thời điểm , chỉ cho phép một Wđược sửa đổi nội dung CSDL.DatabaseR1R2R3W1W2 . 1BÀI 5 : CÁC GIẢI PHÁP ĐỒNG BỘ HOÁNhóm giải pháp Busy Waiting Sử dụng các biến cờ hiệuSử dụng việc kiểm tra luân phiên Giải pháp của Peterson. Được hỗ trợ bởi HĐH Đồng bộ hóa trên môi trường phân tánServer P 1. Send Request2. Receive Accept3. Send Finish 7Các bài toán đồng bộ hoá kinh điểnProducer-Consumer

Ngày đăng: 22/08/2012, 09:06

Từ khóa liên quan

Tài liệu cùng người dùng

Tài liệu liên quan