OPTADS360
AANETWORK
AMBIENT
YOMEDIA
Banner-Video
IN_IMAGE

Sử dụng Test_and_Set để thực hiện loại trừ tương hỗ cho bài toán các triết gia ăn cơm.

  bởi Nguyễn Thị Trang 26/11/2021
ADSENSE/lession_isads=0
QUẢNG CÁO
 

Câu trả lời (1)

  • const int n; //n là số lượng tiến trình

    bool lock;

    void P(int i){    //tiến trình P(i)

      for(;;){    //lặp vô hạn

        while(Test_and_Set(lock)[i]);// lấy đũa bên trái

        while(Test_and_Set(lock)[(i+1)%5]);// lấy đũa bên phải

        <Ăn Cơm>

        lock [i]= false;

        lock [(i+1)%5]= false;

        <Suy nghĩ>

      }

    }

    void main(){

    for(int i=0;I;<5;i++)

      lock [i]= false;

    //tắt tiến trình chính, chạy đồng thời n tiến trình

      StartProcess(P(1)); ….    StartProcess(P(n));

    }

      bởi Mai Vi 26/11/2021
    Like (0) Báo cáo sai phạm

Nếu bạn hỏi, bạn chỉ thu về một câu trả lời.
Nhưng khi bạn suy nghĩ trả lời, bạn sẽ thu về gấp bội!

Lưu ý: Các trường hợp cố tình spam câu trả lời hoặc bị báo xấu trên 5 lần sẽ bị khóa tài khoản

Gửi câu trả lời Hủy
 
 

Các câu hỏi mới

NONE
OFF