Câu 1: (2 điểm) Các trạng thái của 1 tiến trình và mối quan hệ giữa các trạng thái ?
Câu 2: (2 điểm)
Cho các tiến trình có bộ nhớ tương ứng A(300K), B(500K), C(200K), D(200K), E(300K). Sử dụng giải thuật QuickFit với H giảm (trong kỹ thuật phân vùng động) cấp phát bộ nhớ theo trình tự : A→B→C→thu hồi A →D→thu hồi
B→E với dung lượng bộ nhớ dùng để cấp phát là 2000k. Cho biết hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở
các thời điểm cấp phát theo trình tự trên.
9 trang |
Chia sẻ: thanhle95 | Lượt xem: 623 | Lượt tải: 1
Bạn đang xem nội dung tài liệu Đề thi môn Hệ điều hành - Đề số 1 - Đại học Sư phạm Kỹ thuật thành phố Hồ Chí Minh, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 1
ĐỀ THI MÔN : HỆ ĐIỀU HÀNH
Mã môn học : 1180050
Đề số 01. Đề thi có 01 trang
Thời gian làm bài : 75 phút.
Không được phép sử dụng tài liệu.
--------------------------------------------------------
Câu 1: (2 điểm) Các trạng thái của 1 tiến trình và mối quan hệ giữa các trạng thái ?
Câu 2: (2 điểm)
Cho các tiến trình có bộ nhớ tương ứng A(300K), B(500K), C(200K), D(200K), E(300K). Sử dụng giải thuật Quick-
Fit với H giảm (trong kỹ thuật phân vùng động) cấp phát bộ nhớ theo trình tự : A→B→C→thu hồi A →D→thu hồi
B→E với dung lượng bộ nhớ dùng để cấp phát là 2000k. Cho biết hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở
các thời điểm cấp phát theo trình tự trên.
Câu 3: (2 điểm)
Điền số liệu (có giải thích) vào bảng sau. Có tồn tại chuỗi cấp phát an toàn hay không ?. Cho biết tài nguyên ban đầu
của hệ thống.
Allocation
Request
Available
Need
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
P1
1 2 1 1 2 3 3 2 4 2 1
2
1
1
2
P2
1 0 0 1 2 2 2 2 2 3
P3
0 2 0 1 1 3 3 1 4 3
P4
1 2 1 0 1 2 4 4 5 3
P5
1 0 0 0 1 2 1 2 1 1
P6
1 2 1 0 1 2 3 2 1 3
P7
1 0 0 1 1 1 1 1 3 5
P8
2 1 1 0 2 2 4 5 7 2
P9
1 2 1 0 1 3 3 2 6 2
P10
1 1 1 0 1 2 2 2 1 2
Câu 4: (2 điểm) Trình bày giải pháp Semaphore đồng bộ tiến trình : định nghĩa Semaphore, ứng dụng trong truy
xuất độc quyền và hoạt động phối hợp giữa 2 tiến trình (có giải thích).
Câu 5: (2 điểm) Cho chuỗi truy xuất trang :
1 3 0 1 2 1 3 2 1 4 2 5 6 3 1 4 3 6 5 2
Tìm số lỗi trang phát sinh khi sử dụng giải thuật thay trang LRU-Stack với số khung trang trống là 5.
Ghi chú: Cán bộ coi thi không được giải thích đề thi. Ngày 28 tháng 5 năm 2014
Trưởng BM
ĐẠI HỌC SƯ PHẠM KỸ THUẬT TPHCM
KHOA : CÔNG NGHỆ THÔNG TIN
BỘ MÔN : MẠNG
-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐-‐
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 2
ĐÁP ÁN GỢI Ý
Câu 1: (2 điểm)
(Thang điểm: nêu các trạng thái: 0,5 điểm, sơ đồ quan hệ: 1 điểm, giải thích sơ đồ: 0,5 điểm).
New : mới tạo ra.
Ready : sẳn sàng để hoạt động.
Running : hoạt động.
Watting (Blocked) : bị khóa.
Terminated : kết thúc.
1 : Lập lịch.
2 : Cấp CPU và tài nguyên
3 : Đợi I/O hoặc sự kiện của tiến trình.
4 : Đáp ứng I/O hoặc sự kiện của tiến trình.
5 : Interrupt hoặc sự kiện của hệ thống.
6 : Hoàn tất hoạt động.
Mối quan hệ giữa các trạng thái
Các trạng thái:
1
2
3
5
4
6
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 3
Câu 2: (2 điểm) (Thang điểm: trình tự cấp phát: 0,25 điểm, hiện trạng và danh sách: 0,25 điểm cho mỗi
thời điểm cấp phát theo trình tự).
Cấp phát bộ nhớ theo trình tự : A(300K) →B(500K) →C(200K) →thu hồi A →D(200K) →thu hồi B
→E(300K) bằ Quick Fit với H giảm . Sơ đồ cấp phát :
2000K 2000K 2000K 2000K 2000K 2000K 2000K
1200K 1200K 1200K
D D D
1000K 1000K 1000K 1000K 1000K
C C C C C
800K 800K 800K 800K 800K 800K
B B B B
300K 300K 300K 300K 300K 300K
A A A
E
0K 0K 0K 0K 0K 0K 0K
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm cấp phát A(300K)
2000K
300K
A 0K
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm cấp phát B(500K)
2000K
800K
B
300K
A 0K
A 0K 300K
H 300K 1700K
A 0K 300K
B 300K 500K
H 800K 1200
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 4
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm cấp phát C(200K)
2000K
1000K
C
800K
B
300K
A 0K
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm thu hồi A(300K)
2000K
1000K
C
800K
B
300K
0K
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm cấp phát D(200K)
2000K
1200K
D
1000K
C
800K
B
300K
0K
A 0K 300K
B 300K 500K
C 800K 200K
H 1000K 1000K
H 0K 300K
B 300K 500K
C 800K 200K
H 1000K 1000K
H 0K 300K
B 300K 500K
C 800K 200K
D 1000K 200K
H 1200K 800K
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 5
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm thu hồi B(500K)
2000K
1200K
D
1000K
C
800K
0K
Hiện trạng bộ nhớ và danh sách quản lý bộ nhớ ở thời điểm cấp phát E(300K)
2000K
1200K
D
1000K
C
800K
300K
E 0K
H 0K 800K
C 800K 200K
D 1000K 200K
H 1200K 800K
E 0K 300K
H 300K 500K
C 800K 200K
D 1000K 200K
H 1200K 800K
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 6
Câu 3: (2 điểm) (Thang điểm: điền dữ liệu vào bảng: 0,5 điểm, giải thích: 0,5 điểm, kết luận: 0,5 điểm, tài
nguyên ban đầu: 0,5 điểm).
Allocation
Request
Available
Need
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
R1
R2
R3
R4
R5
TT
Cấp
P1
1 2 1 1 2 3 3 2 4 2 1
2
1
1
2
2
1
1
3
0
(5)
P2
1 0 0 1 2 2 2 2 2 3 2
4
2
1
3
1
2
2
1
1
(2)
P3
0 2 0 1 1 3 3 1 4 3 3
4
2
2
5
3
1
1
3
2
(6)
P4
1 2 1 0 1 2 4 4 5 3 4
4
2
2
6
1
2
3
5
2
(7)
P5
1 0 0 0 1 2 1 2 1 1 5
4
2
3
7
1
1
2
1
0
(3)
P6
1 2 1 0 1 2 3 2 1 3 6
6
3
4
9
1
1
1
1
2
(1)
P7
1 0 0 1 1 1 1 1 3 5 6
8
3
5
10
0
1
1
2
4
(4)
P8
2 1 1 0 2 2 4 5 7 2 7
10
4
5
11
0
3
4
7
0
*
P9
1 2 1 0 1 3 3 2 6 2
2
1
1
6
1
*
P10
1 1 1 0 1 2 2 2 1 2
1
1
1
1
1
(8)
10
13
6
5
14
(1)Available
=
(1,2,1,1,2)
→
Need
=
((1,1,1,1,2)
P6
(2)Available
=
(1,2,1,1,2)
+
Allocation
P6(1,2,1,0,1)
=
(2,4,2,1,3)
→
Need
=
(1,2,2,1,1)
P2
(3)Available
=
(2,4,2,1,3)
+
Allocation
P2(1,0,0,1,2)
=
(3,4,2,2,5)
→
Need
=
(1,1,2,1,0)
P5
(4)Available
=
(3,4,2,2,5)
+
Allocation
P5(1,0,0,0,1)
=
(4,4,2,2,6)
→
Need
=
(0,1,1,2,4)
P7
(5)Available
=
(4,4,2,2,6)
+
Allocation
P7(1,0,0,1,1)
=
(5,4,2,3,7)
→
Need
=
(2,1,1,3,0)
P1
(6)Available
=
(5,4,2,3,7)
+
Allocation
P1(1,2,1,1,2)
=
(6,6,3,4,9)
→
Need
=
(3,1,1,3,2)
P3
(7)Available
=
(6,6,3,4,9)
+
Allocation
P3(0,2,0,1,1)
=
(6,8,3,5,10)
→
Need
=
(1,2,3,5,2)
P4
(8)Available
=
(6,8,3,5,10)
+
Allocation
P4(1,2,1,0,1)
=
(7,10,4,5,11)
Available
=
(7,10,4,5,11)
không
cấp
được
cho
Need=(0,3,4,7,0)P8,
Need(2,1,1,6,1)P9
Kết
luận
:
không
tồn
tại
chuỗi
cấp
phát
an
toàn.
Tài
nguyên
ban
đầu
:
(10,13,6,5,14).
Câu 4: (2 điểm) (Thang điểm: định nghĩa Semaphore: 0,5 điểm, mỗi ứng dụng: 0,75(cấu trúc lại:0,25,
giải thích: 0,5 điểm)).
ĐN : Semaphore S là 1 số nguyên không âm.
S chỉ có thể bị thay đổi bởi 2 hàm
Signal(S)=S+1
S-1; S>0
Wait(S)=
Chờ khi S>0; S=0
Trong thời gian thay đổi S, không có sự tham gia của bất kỳ TT
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 7
Hàm wait() và signal()
wait(S) {
while S <= 0; // no-op
S=S-1;
}
signal(S) {
S=S+1;
}
*Ứng dụng Semaphore trong truy xuất độc quyền
VD : P1, P2 cùng truy xuất Buffer
P1 đặt data vào Buffer
P2 lấy data từ Buffer
Vấn đề : P1, P2 không thể cùng truy xuất Buffer
Miền Găng P1 : đoạn CT đặt data vào Buffer
Miền Găng P2 : đoạn CT lấy data từ Buffer
S Semaphore truy xuất Buffer (S=1)
Cấu trúc lại miền Găng P1, P2 :
Giải thích:
Kết luận : P1, P2 không thể truy xuất đồng thời.
P1
Wait(S);
đoạn CT đặt data vào Buffer;
Signal(S);
P2
Wait(S);
đoạn CT lấy data từ Buffer;
Signal(S);
(GS P1 được cấp CPU trước)
P1:
Wait(s) : s=0
Data→Buff
→(PCB P1)
Trả CPU
-----------------
P2:
Wait(s) : chờ (vì s=0)
→(PCB P2)
Trả CPU
-----------------
P1:
(PCB P1) →
Data→Buff
Signal(s) : s=1
→(PCB P1)
Trả CPU
-----------------
P2:
(PCB P2) →
Wait(s) : s=0
Data←Buff
→(PCB P2)
Trả CPU
-----------------
P1:
(PCB P1) →
Wait(s) : chờ (vì s=0)
→(PCB P1)
Trả CPU
-----------------
P2:
(PCB P2) →
Data ←Buff
Signal(s) : s=1
→(PCB P2)
Trả CPU
-----------------
P1:
(PCB P1) →
Wait(s) : s=0
-----------------
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 8
*Ứng dụng Semaphore trong hoạt động phối hợp
VD : tác vụ X = tác vụ X1+tác vụ X2
(tác vụ X1 thực hiện trước, tác vụ X2 thực hiện sau để kết thúc tác vụ X)
P1 thực hiện tác vụ X1
P2 thực hiện tác vụ X2
Vấn đề : tác vụ X1 thực hiện trước cho đến khi hoàn thành
thì mới thực hiện tác vụ X2 và khi thực hiện xong
tác vụ X2 thì kết thúc tác vụ X (không thực hiện lại tác vụ X1).
Miền Găng : đoạn CT trong P1 thực hiện tác vụ X1, đoạn CT trong P2
thực hiện tác vụ X2.
S Semaphore kiểm soát truy xuất đồng thời P1, P2 (S=1)
Cấu trúc lại miền Găng P1, P2 :
Giải thích:
P1
Wait(S);
Đoạn CT P1;
Signal(S);
P2
Wait(S);
Đoạn CT P2;
(GS P1 được cấp CPU trước)
P1:
Wait(s) : s=0
Tác vụ X1
→(PCB P1)
Trả CPU
-----------------
P2
Wait(s) : chờ (vì s=0)
→(PCB P2)
Trả CPU
-----------------
P1
(PCB P1) →
Tác vụ X1
Signal(s) : s=1
→(PCB P1)
Trả CPU
-----------------
P2:
(PCB P2) →
Wait(s) : s=0
Tác vụ X2
→(PCB P2)
Trả CPU
-----------------
P1
(PCB P1) →
Wait(s) : chờ (vì s=0)
→(PCB P1)
Trả CPU
-----------------
P2
(PCB P2) →
Tác vụ X2
(Xong)
→(PCB P2)
Trả CPU
-----------------
P1
(PCB P1) →
Wait(s) : chờ (vì s=0)
→(PCB P1)
Trả CPU
-----------------
P2
(PCB P2) →
Wait(s) : chờ (vì s=0)
→(PCB P2)
Trả CPU
-----------------
(Hoàn thành tác vụ X)
Số hiệu: BM1/QT-KĐ-RĐTV/00 Trang 9
Câu 5: (2 điểm) (Thang điểm: Bảng LRU: 1 điểm, lỗi trang: 0,5 điểm, bảng Stack: 0,5 điểm).
1 3 0 1 2 1 3 2 1 4 2 5 6 3 1 4 3 6 5 2
1 1 1 1 1 1 1 1 1 1 1 1 1 3 3 3 3 3 3 3
3 3 3 3 3 3 3 3 3 3 3 6 6 6 6 6 6 6 6
0 0 0 0 0 0 0 0 0 5 5 5 5 5 5 5 5 5
2 2 2 2 2 2 2 2 2 2 2 4 4 4 4 4
4 4 4 4 4 1 1 1 1 1 2
* * * * * * * * * * *
4 2 5 6 3 1 4 3 6 5 2
2 1 3 2 1 1 4 2 5 6 3 1 4 3 6 5
0 1 1 2 1 3 2 2 1 4 2 5 6 3 1 4 3 6
3 3 0 0 0 2 1 3 3 3 1 4 2 5 6 6 1 4 3
1 1 1 3 3 3 0 0 0 0 0 3 1 4 2 5 5 5 1 4
Số lỗi trang : 11