← PC・IT用語集へ戻る

コア

Core
general development beginner
ハードウェアやソフトウェアの中で、中心的な処理や基本機能を担う部分。
コア (Core)

概要(サマリー)

コア(Core)とは、ハードウェアやソフトウェアの中で、中心的な処理や基本機能を担う部分を表す言葉である。

ハードウェアの話では、主にCPU内部で命令を処理する演算部分を指す。ソフトウェアの話では、追加機能や見た目の部品ではなく、システムを動かす土台となる本体部分を指すことが多い。

同じ「コア」でも文脈によって意味が変わるため、CPUの話か、ソフトウェアの構成の話かを確認することが重要である。

詳細解説

1. CPUにおけるコア

CPUコアは、プログラムの命令を読み取り、計算やデータ処理を進める演算部分である。CPUという一つの製品の中に、複数のコアが搭載されていることも多い。

コアが一つのCPUをシングルコア、複数あるCPUをマルチコアと呼ぶ。デュアルコアは2基、クアッドコアは4基、オクタコアは8基の物理コアを表す呼び方である。

2. マルチコアと並列処理

複数のコアを使うと、異なる処理を分担したり、一つの大きな処理を小さく分けたりできる。複数の作業員が担当を分けるイメージに近い。

たとえば、動画のエンコード、ソフトウェアのビルド、科学計算などは、処理を分割できれば複数コアの効果を得やすい。一方で、順番どおりに一つずつ進める必要がある処理は、コア数を増やしても大きく速くならないことがある。

3. 物理コアと論理コア

物理コアは、CPU上に実際に存在する演算回路である。論理コアは、OSから独立した処理単位として見える実行枠を指す。

たとえば、Intel Hyper-Threading Technologyでは、一つの物理コアが二つの論理コアとして見える場合がある。ただし、論理コアが二つあるからといって、物理コアが二つに増えたわけではない。

OSやプログラムが表示する「CPU数」が、物理コア数ではなく論理コア数を指すこともある。この違いを理解しないまま性能を比較すると、数字を読み違えやすい。

4. コア数だけでは性能は決まらない

CPUの性能はコア数だけで決まらない。1秒あたりの動作の目安となるクロック周波数、CPUの設計、キャッシュ、消費電力、冷却、実行するソフトウェアなども影響する。

また、アプリケーション側が複数の処理を並行して実行できるように作られていなければ、多数のコアを十分に使えない。用途に合うCPUを選ぶには、コア数と1コアあたりの性能の両方を見る必要がある。

5. ソフトウェアにおけるコア

ソフトウェアの「コア」は、その製品やシステムの基本機能を担う中核部分を意味する。プラグイン、テーマ、追加モジュールなどと区別するために使われる。

たとえば、WordPressの「コアアップデート」は、テーマや個別のプラグインではなく、WordPress本体を更新することを指す。コアファイルを直接編集すると、更新時に変更が失われたり、保守が難しくなったりするため、通常は推奨されない。

6. プログラムから利用可能な並列度を調べる

Node.jsでは、os.availableParallelism()を使うと、そのプログラムが利用する並列度の目安を取得できる。

const os = require("node:os");

const parallelism = os.availableParallelism();

console.log(`推奨される並列度: ${parallelism}`);

この値は「物理コア数」そのものではない。コンテナやOSの制限も考慮した、アプリケーションが利用できる並列度の目安である。

os.cpus().lengthは論理CPUの情報数を返すため、物理コア数の取得や利用可能な並列度の計算にそのまま使うと不正確になる場合がある。

AIコーディングとの関係

AIは、CPUを活用する並列処理、ワーカープロセス、バッチ処理などのコード案を作れる。また、ソフトウェア設計で「中核機能」と「追加機能」を分ける相談にも利用できる。

コード生成を依頼するときは、「CPU負荷が中心か、入出力待ちが中心か」「実行環境は何か」「処理順序を守る必要があるか」「最大でいくつ並行実行するか」を伝えるとよい。

ただし、並列度を上げれば常に速くなるわけではない。メモリ使用量、処理の競合、外部APIの制限、エラー時の再実行などを確認し、小さな負荷試験で効果を測る必要がある。

よくある勘違い

コア数が多ければ、どんなアプリでも速くなる?

必ずしも速くならない。アプリケーションが処理を分割できない場合や、ストレージ・ネットワークの待ち時間がボトルネックの場合は、コア数を増やしても効果が小さい。

8コア16スレッドは16個の物理コアがある?

違う。一般に「8コア16スレッド」は8個の物理コアがあり、OSから16個の論理的な実行枠として見える構成を表す。

ソフトウェアのコアとライブラリは同じ?

同じとは限らない。コアは製品の基本機能を担う本体部分を指し、ライブラリやプラグインは再利用する部品や追加機能を指すことが多い。

os.cpus().lengthで物理コア数が分かる?

通常は分からない。この値は論理CPUの数に対応するため、物理コア数とは一致しない場合がある。

まとめ

  • CPUコアは、命令の実行や計算を担う演算部分である
  • マルチコアは処理を分担できるが、ソフトウェア側の対応も必要である
  • 物理コアと論理コアは異なり、表示されるCPU数が物理コア数とは限らない
  • CPU性能はコア数だけでなく、クロック周波数や設計、実行する処理にも左右される
  • ソフトウェアのコアは、システムの基本機能を担う中核部分を指す

情報ソース

より詳しくAIに聞いてみよう

  • CPUコアの役割を、初心者向けに具体例で説明してください。
  • 物理コア、論理コア、スレッドの違いを整理してください。
  • コア数とクロック周波数のどちらを重視すべきか、用途別に説明してください。
  • CPU負荷の高い処理をマルチコア化するときの注意点を教えてください。
  • Node.jsで利用可能な並列度に合わせてワーカー数を調整するコードを作成してください。