SwiftのfatalErrorとpreconditionを徹底解説!初心者でも理解できる例外的状況への備え方
生徒
「先生、Swiftのコードを見ていたらfatalErrorとかpreconditionって出てきたんですが、これって何ですか?」
先生
「これはSwiftで例外的な状況に備えるための仕組みです。つまり“絶対に起きてはいけない状態”になったときに、プログラムを強制的に止めたり確認をするために使います。」
生徒
「普通のエラーハンドリングとは違うんですか?」
先生
「そうです。通常のエラー処理はdo-catchやguardで行いますが、fatalErrorやpreconditionは“そもそも絶対にその状況になってはいけない”という時に使うんです。」
1. fatalErrorとは?
fatalErrorは、その名の通り「致命的なエラー」を発生させてプログラムを強制終了するための関数です。例えば「この関数は必ずオーバーライドされるべきなのに呼ばれてしまった」といった場合に使います。
初心者向けに説明すると、「赤信号で車が進んでしまったら即座に警察が止める」ようなイメージです。プログラムがそのまま進むと危険なので、強制的に止める役割を持っています。
func mustOverride() {
fatalError("このメソッドはサブクラスで必ずオーバーライドしてください")
}
このコードを実行すると、その場でアプリが止まり、指定したメッセージが表示されます。
Fatal error: このメソッドはサブクラスで必ずオーバーライドしてください
2. preconditionとは?
preconditionは「事前条件」を確認するための関数です。条件が満たされない場合にプログラムを停止させます。これは「この条件は絶対に成り立っているはずだ」という想定をチェックするために使われます。
例えば「年齢は必ず0以上であるべき」という状況で、負の数が来たらプログラムを止める、という用途です。
func setAge(_ age: Int) {
precondition(age >= 0, "年齢は0以上でなければなりません")
print("年齢は\(age)歳です")
}
もしマイナスの数を渡すと、実行時にエラーが発生してプログラムが止まります。
Precondition failed: 年齢は0以上でなければなりません
3. fatalErrorとpreconditionの違い
両者は似ていますが、目的と使いどころが少し違います。
- fatalError:絶対に到達してはいけないコードに到達したときに使う。
- precondition:必ず満たすべき条件が破られたときに使う。
つまり、fatalErrorは「ここに来ること自体がバグ」という場合に、preconditionは「引数や状態が不正な場合を検出」するのに使います。
4. 例外的状況と通常のエラー処理の違い
通常のエラー処理(do-catchやthrows)は「起こり得るエラー」に対応するために使います。例えば「ネットワークが切れる」「ファイルが見つからない」といった予想可能な状況です。
一方で、fatalErrorやpreconditionは「そもそも設計上あり得ないはずの状況」を検出するために使います。これは開発中にバグを見つける助けにもなり、予期せぬ挙動を早めに発見できるのです。
5. 実際の開発での使い分け
初心者が迷いやすいポイントは「どこでfatalErrorを使っていいのか」という点です。基本的には、ユーザーの操作ミスや外部環境によるエラーには使わず、あくまでプログラムの内部ロジックが間違っている場合にだけ使います。
- ユーザー入力の不備 → guardやif文で対応
- ネットワークの失敗 → do-catchでエラーハンドリング
- 想定外のロジック到達 → fatalError
- 引数チェックで不正値を排除 → precondition
このように整理して考えると、エラーハンドリングの役割分担が分かりやすくなります。
6. fatalError・preconditionを使うときの注意点
これらを使いすぎると、ユーザーが利用中にアプリが強制終了してしまう危険があります。そのため、基本的には開発中のデバッグやテストの段階でバグを早期に発見するために活用し、リリース後のアプリではなるべく使わないのが安全です。
特に初心者のうちは「プログラムを止める道具」ではなく「開発中に不正な状態をチェックする道具」として理解しておくと混乱が少ないでしょう。