ア | イ | ウ | エ | オ |
カ | キ | ク | ケ | コ |
サ | シ | ス | セ | ソ |
タ | チ | ツ | テ | ト |
ナ | ニ | ヌ | ネ | ノ |
ハ | ヒ | フ | ヘ | ホ |
マ | ミ | ム | メ | モ |
ヤ | ユ | ヨ | ||
ラ | リ | ル | レ | ロ |
ワ | ヰ | ヴ | ヱ | ヲ |
ン |
A | B | C | D | E |
F | G | H | I | J |
K | L | M | N | O |
P | Q | R | S | T |
U | V | W | X | Y |
Z | 数字 | 記号 |
一つ以上のプログラムが、あたかも同時に動いているかのように見える機構のこと。またこのような機能を有するオペレーティングシステム(OS)を、マルチタスクオペレーティングシステムという。
タスクは、OSにおける処理の単位である。このタスクをどのような粒度(Granularity)で実行するかを、プロセスまたはスレッドという。
古いシステムで同時に一つのタスクしか実行できないものをシングルタスクというのに対し、近代的なOSでは複数のタスクをプロセスとして動作させ、各プロセスが一つ以上のスレッドを生成することで、システムとして並列処理を実現している。複数(マルチ)が可能なため、これをマルチタスクという。
動作中のプログラムは、それぞれがタスク(またはプロセス)と呼ばれ、一つのコマンドやアプリケーションを実行すると、少なくとも一つの新しいタスク(プロセス)が開始される。また、システムを機能させるため、常に動作しているタスク(プロセス)も多数ある。
複数のタスクをどのように管理しCPU時間を割り当てるかは、そのOSの設計により異なる。
大きくは二通りに分けられる。
OS自体がCPU時間を管理し、随時タスクへ時間を与える方式を「プリエンプティブマルチタスク」と呼び、管理をアプリケーション側に任せる方式を「ノンプリエンプティブマルチタスク」と呼ぶ。
但し後者は、正確にはマルチタスクとは言わないともされる。
各タスクに対し、どのような粒度でCPUの実行時間を割り当てるかにより、大きく次の二通りに分けられる。
近代的なOSではマルチスレッドが一般的で、このようなシステムを「マルチスレッドオペレーティングシステム」という。
コメントなどを投稿するフォームは、日本語対応時のみ表示されます