blob: 78c6fa8a47e2d826f7b79821b7cf326cf3f91338 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
---
title: Asynchronous(非同期)
slug: Glossary/Asynchronous
tags:
- Glossary
- Web
- WebMechanics
translation_of: Glossary/Asynchronous
---
<p><span class="seoSummary"><em>非同期</em>とは、2つ以上の事象が同時に発生したり、関連する複数の事象が互いの完了を待たずに発生したりする概念を指します (前のものが完了するのを待たずに複数の関連するものが発生することもあります)。</span> コンピュータの世界では、「非同期」という言葉は主に2つの文脈で使われています。</p>
<dl>
<dt>ネットワークと通信</dt>
<dd>
<p>非同期通信とは、2人以上の通信者の間で、それぞれが都合の良いタイミングでメッセージを受信し処理する通信方式です。受信者は、受信直後に処理をする必要はありません。また、問題発生時には受信者が訂正をリクエストしたり問題を処理したりするという了解の下で、メッセージは受信者の確認を待たずに送信されるかもしれません。</p>
<p>人の場合、電子メールは非同期通信の1つです。送信者がメールを送信すると、受信者は受信直後ではなく都合の良いタイミングでメッセージを読んで返信します。両者ともに、好きなときに送信や受信を継続でき、お互いにスケジュールを調整する必要はありません。</p>
<p>ソフトウェアが非同期に通信する場合、プログラムは別のソフトウェア(サーバーなど)から情報を要求し、応答を待っている間、他のことをし続けることができます。例えば、<a href="/ja/docs/Web/Guide/AJAX">AJAX</a> (Asynchronous JavaScript and {{Glossary("XML")}}) プログラミングテクニック - 現代のアプリケーションでは XML ではなく {{Glossary("JSON")}} が通常使用されていますが、現在では単に "Ajax" と呼ばれています - は、 {{Glossary("HTTP")}} を使用してサーバーに比較的少量のデータを要求し、その結果はすぐにではなく利用可能なときに返される仕組みです。</p>
</dd>
<dt>ソフトウェア設計</dt>
<dd>
<p>非同期ソフトウェアの設計は、プログラム中で元のタスクを止めることなく、別のタスクを同時に実行させることを可能にするものです。2つ目のタスクが完了した時、合意された仕組みを使い、その情報が元のタスクに通知されます。それにより、元のタスクは、処理が完了し結果が利用可能になったことを把握できるのです。</p>
<p>非同期ソフトウェアを実装するプログラミング・テクニックは数多くあります。学んでみたければ、<a href="/ja/docs/Learn/JavaScript/Asynchronous">Asynchronous JavaScript</a>の記事をご覧下さい。</p>
</dd>
</dl>
<h2 id="Learn_more" name="Learn_more">詳細情報</h2>
<h3 id="Technical_reference" name="Technical_reference">技術リファレンス</h3>
<ul>
<li><a href="/ja/docs/Learn/JavaScript/Client-side_web_APIs/Fetching_data">Fetching data from the server</a> (Learning Area)</li>
<li>{{glossary("Synchronous")}}</li>
</ul>
<p>{{IncludeSubnav("/ja/docs/Glossary")}}</p>
|