ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
switch 文とは
switch 文は、ある式の値によって処理を多方向へ分岐させる制御構文です。if-else if のチェーンと意味的には似ていますが、同じ式を 1 回評価して候補と照合するため、可読性とパフォーマンスで有利なケースが多いです。
基本構文(Java / C / C++)
int day = 3;
switch (day) {
case 1:
System.out.println("月曜");
break;
case 2:
System.out.println("火曜");
break;
case 3:
System.out.println("水曜");
break;
default:
System.out.println("その他");
}
JavaScript の例
JavaScript の switch は厳密比較(===)で照合します。型が違うと一致しません。
const fruit = 'apple';
switch (fruit) {
case 'apple':
console.log('赤い');
break;
case 'banana':
console.log('黄色い');
break;
default:
console.log('未知の果物');
}
// 厳密比較なので数値と文字列は一致しない
const n = '1';
switch (n) {
case 1: console.log('数値の1'); break; // ここには来ない
case '1': console.log('文字の1'); break; // こっち
}
フォールスルー(break 忘れ)
break を書き忘れると、次の case の処理にそのまま流れ込みます。これをフォールスルーと呼び、意図的にまとめるテクニックとしても使われます。
switch (day) {
case 'mon':
case 'tue':
case 'wed':
case 'thu':
case 'fri':
console.log('平日');
break;
case 'sat':
case 'sun':
console.log('週末');
break;
}
default の位置
default はどの case にも一致しなかった場合の処理です。書く位置はどこでも構いませんが、末尾に置くのが読みやすく一般的です。中間に置くときも break を忘れないでください。
switch 式(モダンな書き方)
Java 14+ / C# 8+ などには値を返す switch 式が導入されています。break が要らず、矢印で結ぶスタイルが主流です。
// Java 14+ の switch 式(矢印形式)
String label = switch (day) {
case 1, 2, 3, 4, 5 -> "平日";
case 6, 7 -> "週末";
default -> "不明";
};// C# 8+ の switch 式
string label = day switch
{
1 or 2 or 3 or 4 or 5 => "平日",
6 or 7 => "週末",
_ => "不明"
};
Python の match 文 (3.10+)
Python には伝統的に switch がありませんでしたが、3.10 から構造的パターンマッチとして match 文が入りました。単純な多分岐から、リスト・辞書の構造分解まで対応します。
match status:
case 200 | 201:
print('OK')
case 404:
print('Not Found')
case 500 | 502 | 503:
print('Server Error')
case _: # default 相当
print('Other')
# 構造マッチ
match point:
case (0, 0): print('原点')
case (x, 0): print(f'X軸 {x}')
case (0, y): print(f'Y軸 {y}')
case (x, y): print(f'平面 ({x},{y})')
if-else との使い分け
| 状況 | 向き |
|---|---|
| 同じ値を多方向で比較 | switch |
| 範囲条件 / 複合条件 | if-else |
| 列挙型 / 定数の網羅 | switch(コンパイラが網羅性チェック) |
| 2 〜 3 分岐 | if / 三項演算子で十分 |
よくある落とし穴
- break 忘れでフォールスルー → 想定外の処理が走る
- JS では === 比較なので型不一致でハマる(
1と'1') - case 内で変数宣言するときはブロック
{ ... }で囲む(Java の重複宣言エラー回避) - case ラベルは定数式に限られる言語が多い(Java / C / C#)
- 列挙型での switch は新しい値を追加したときの網羅漏れに注意(コンパイラ警告を活用)
関連
- if文 — 2 方向分岐
- if-else文 — 多方向分岐
- 三項演算子 — 簡潔な 2 方向式
- 条件分岐 — 親カテゴリ
- 列挙型 — switch との相性が良い
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- if文 (条件分岐)
- switch文
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?