2020年12月27日

令和2年度秋期 応用情報技術者試験問題 問17

問17

三つの資源X〜Zを占有して処理を行う四つのプロセスA〜Dがある。各プロセスは処理の進行に伴い、表中の数値の順に資源を占有し、実行終了時に三つの資源を一括して解放する。プロセスAと同時にもう一つプロセスを動かした場合に、デッドロックを起こす可能性があるプロセスはどれか。

 ┌────┬───────────┐
 │    │  資源の占有順序  │
 │プロセス├───┬───┬───┤
 │    │資源X│資源Y│資源Z│
 ├────┼───┼───┼───┤
 │  A  │ 1 │ 2 │ 3 │
 ├────┼───┼───┼───┤
 │  B  │ 1 │ 2 │ 3 │
 ├────┼───┼───┼───┤
 │  C  │ 2 │ 3 │ 1 │
 ├────┼───┼───┼───┤
 │  D  │ 3 │ 2 │ 1 │
 └────┴───┴───┴───┘

ア B、C、D

イ C、D

ウ Cだけ

エ Dだけ





正解


解説

実行終了時に三つの資源を一括して解放するため、以下の場合にデッドロックが発生する。

■プロセスAとCの場合
@Aが資源Xを占有する。
ACが資源Zを占有する。
BAが資源Yを占有する。
CCが資源Zを占有したまま資源Xの解放待ち
 同時にAが資源X・Yを占有したまま、資源Zの解放待ち

■プロセスAとDの場合
@Aが資源Xを占有する。
ADが資源Zを占有する。
BAが資源Yを占有する。
CDが資源Zを占有したまま資源Yの解放待ち
 同時にAが資源X・Yを占有したまま資源Zの解放待ち

なおプロセスAとBは
@Aが資源Xを占有する。
ABが資源Xの解放待ち。
BAが資源Yを占有する。
CAが資源Zを占有する。
DAの実行終了。資源をすべて解放。
EBが資源Xを占有する。
FBが資源Yを占有する。
GBが資源Zを占有する。
HBの実行終了。資源をすべて解放。
となり、デッドロックは発生しない。

posted by ファーストマクロ at 10:35| Comment(0) | R02秋応用情報技術者
この記事へのコメント
コメントを書く
お名前:

メールアドレス:

ホームページアドレス:

コメント:

認証コード: [必須入力]


※画像の中の文字を半角で入力してください。