blob: 077125a53d37a9abf26af6b3e12cdf057efea429 (
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
---
title: navigator.hardwareConcurrency
slug: Web/API/NavigatorConcurrentHardware/hardwareConcurrency
translation_of: Web/API/NavigatorConcurrentHardware/hardwareConcurrency
---
<p>{{APIRef("HTML DOM")}}</p>
<p>{{AvailableInWorkers}}</p>
<p><code><strong>navigator.hardwareConcurrency</strong></code> はユーザーのコンピューター上でスレッドを実行するために使用可能な論理プロセッサ数を返す読み取り専用のプロパティです。</p>
<h2 id="構文">構文</h2>
<pre class="syntaxbox"><em>logicalProcessors</em> = window.navigator.hardwareConcurrency
</pre>
<h2 id="値">値</h2>
<p>論理プロセッサのコア数を示す{{jsxref("Number")}}です。</p>
<p>現代のコンピューターはCPUに複数の物理プロセッサのコアを持っています(通常は2コアか4コア)。しかし、通常それぞれの物理コアは高度なスケジューリング技術を用いて一度に複数スレッドを実行することができます。 したがって、例えば4コアのCPUは8個の<strong>論理プロセッサコア</strong>を提供することができます。論理プロセッサのコア数は、コンテキストスイッチを必要とせずに一度に効果的に実行できるスレッドの数を測定するために使用できます。</p>
<p>しかしながら、ブラウザはより少ない論理コア数を報告することを選択することで、一度に実行できる{{domxref("Worker")}}の数をより正確に表すことがあります。したがって、この数値をユーザーのシステムのコア数の絶対的な測定値として扱わないようにしてください。</p>
<h2 id="例">例</h2>
<p>この例では、ブラウザが報告した論理プロセッサごとに{{domxref("Worker")}}が1つ作られ、新しいWorkerへの参照と、そのWorkerをまだ使用しているかどうかを示すBooleanの値を含むレコードを作っています。これらのオブジェクトは後で使用するために配列に順々に格納されています。後でリクエストを処理するために使うWorkerのプールを作っています。</p>
<pre class="brush: js">let workerList = [];
for (let i = 0; i < window.navigator.hardwareConcurrency; i++) {
let newWorker = {
worker: new Worker('cpuworker.js'),
inUse: false
};
workerList.push(newWorker);
}</pre>
<h2 id="仕様">仕様</h2>
<table class="standard-table">
<tbody>
<tr>
<th scope="col">Specification</th>
<th scope="col">Status</th>
<th scope="col">Comment</th>
</tr>
<tr>
<td>{{SpecName('HTML WHATWG', '#dom-navigator-hardwareconcurrency', 'navigator.hardwareConcurrency')}}</td>
<td>{{Spec2('HTML WHATWG')}}</td>
<td>Initial definition.</td>
</tr>
</tbody>
</table>
<h2 id="ブラウザでの実装状況">ブラウザでの実装状況</h2>
<div>
<p>{{Compat("api.NavigatorConcurrentHardware.hardwareConcurrency")}}</p>
</div>
<h2 id="関連情報">関連情報</h2>
<ul>
<li>{{domxref("Navigator")}}</li>
<li>{{domxref("WorkerNavigator")}}</li>
</ul>
|