カテゴリ: Kotlin 更新日: 2026/05/05

Kotlinのthrow文の使い方!例外を明示的に投げる方法

Kotlinのthrow文の使い方!例外を明示的に投げる方法
Kotlinのthrow文の使い方!例外を明示的に投げる方法

先生と生徒の会話形式で理解しよう

生徒

「Kotlinのthrow文って何ですか?どうやって使うんですか?」

先生

throw文は、プログラムの中で意図的に例外を発生させるための命令です。」

生徒

「意図的にエラーを起こすってどういうことですか?」

先生

「例えば、入力が間違っているときにエラーを投げて処理を止めることができます。実際の例を見ながら学んでいきましょう。」

1. throw文とは?(意図的にエラーを発生させる理由)

1. throw文とは?(意図的にエラーを発生させる理由)
1. throw文とは?(意図的にエラーを発生させる理由)

Kotlinのthrow文は、プログラムの中で「ここでおかしいことが起きた!」と明示的に宣言し、あえて例外(エラー)を発生させるための命令です。

「エラーは出ない方がいいのでは?」と思うかもしれませんが、実は逆です。例えば、銀行の引き出し処理で残高が足りないのに処理が進んでしまったら大変ですよね?そういった「プログラム的にあり得ない状況」が発生した際、throwを使って即座に処理を中断させることで、重大なバグやデータの破損を未然に防ぐことができるのです。

未経験者向けイメージ:
料理のレシピ(プログラム)を実行中に「メインの肉が入っていない」という致命的なミスを見つけた時、そのまま作り続けずに「材料不足エラー!」と叫んで作業を止めるのがthrowの役割です。

throwが実行されると、その後の処理は一切行われず、プログラムは「このエラーを解決できる人(catch文など)」を探しにいきます。もし誰も解決してくれない場合は、アプリが停止します。


fun main() {
    println("処理を開始します")

    // throwを実行した瞬間に、これ以降のコードは無視されます
    throw Exception("重大なエラーが発生しました!")

    println("この行は実行されません") 
}

このように、throwの直後に指定した「例外オブジェクト」が、エラーの原因や詳細を呼び出し元に伝えるメッセージカードのような役割を果たします。

2. throw文の基本構文と使い方

2. throw文の基本構文と使い方
2. throw文の基本構文と使い方

Kotlinで「意図的にエラーを発生させる」ために使用するのがthrow文です。プログラムを実行している途中で、「これ以上処理を続けると問題がある」と判断したときに、自ら例外を投げることができます。

まずは、最もシンプルな書き方を見てみましょう。プログラミングが初めての方でも、以下のコードで「エラーを投げる」イメージを掴んでみてください。


fun main() {
    // 例外(エラー)を意図的に発生させる
    throw Exception("システムに予期せぬエラーが発生しました")
}

このコードを実行すると、プログラムはその時点で停止し、指定した"システムに予期せぬエラーが発生しました"というメッセージが表示されます。

基本構造はthrow 例外オブジェクトという形になります。Exceptionは「何か問題が起きました」という一般的なエラーを表すクラスです。カッコの中には、開発者やログを確認する人が「なぜエラーが起きたのか」を一目で理解できるような具体的なメッセージを記述するのが、良いプログラムを書くためのコツです。

たとえば、「入力された値が空だった場合」や「対象のデータが見つからなかった場合」など、特定の条件を満たさないときにこのthrowを使って処理を中断させ、安全にエラーを通知する仕組みを作ることができます。

3. Kotlinでの例外処理:基本的な使い方(try-catchとthrow)

3. Kotlinでの例外処理:基本的な使い方(try-catchとthrow)
3. Kotlinでの例外処理:基本的な使い方(try-catchとthrow)

プログラムを実行していると、入力ミスなどの予期せぬ事態で「エラー」が発生することがあります。Kotlinでは、このエラーを**「例外(Exception)」**と呼びます。 例外が発生した際に、プログラムを強制終了させずに「適切に処理する」ための仕組みが**try-catch**構文です。

例外を発生させる(throw)と捕まえる(try-catch)

まずは、簡単な「年齢チェック」のプログラムを例に見てみましょう。 例えば、年齢を入力する欄に「-5歳」のようなありえない数値が入ってきた場合、プログラム側から「それはおかしいですよ!」と警告を出す(投げ出す)のがthrowの役割です。


// 1. 例外を発生させる関数(チェック機能)
fun checkAge(age: Int) {
    if (age < 0) {
        // 「不正な引数です」という例外をわざと発生させる
        throw IllegalArgumentException("年齢にマイナスの値は入力できません。")
    }
    println("入力された年齢は $age 歳です。")
}

fun main() {
    try {
        // 2. 実行したい処理(エラーが起きるかもしれない場所)
        checkAge(-5) 
    } catch (e: IllegalArgumentException) {
        // 3. 例外が発生した時の対策(リカバリー処理)
        println("【入力エラー】${e.message}")
    } finally {
        // 4. エラーの有無に関わらず最後に必ず実行される(任意)
        println("チェック処理が完了しました。")
    }
}

実行結果の確認


【入力エラー】年齢にマイナスの値は入力できません。
チェック処理が完了しました。

このサンプルでは、checkAge(-5)が実行された瞬間にIllegalArgumentExceptionが投げられます。 しかし、それをtry-catchブロックで囲んでいるため、画面にエラーメッセージを表示して、プログラムを安全に継続させることができています。

初心者の方は、まず**「エラーが起きそうな場所をtryで囲み、起きた後の対処法をcatchに書く」**という基本の流れをマスターしましょう。

4. throw文とカスタム例外

4. throw文とカスタム例外
4. throw文とカスタム例外

Kotlinでは独自の例外クラスを作ってthrowすることもできます。


class InvalidScoreException(message: String) : Exception(message)

fun checkScore(score: Int) {
    if (score !in 0..100) {
        throw InvalidScoreException("スコアは0から100の間でなければなりません")
    }
    println("スコアは $score 点です")
}

fun main() {
    try {
        checkScore(120)
    } catch (e: InvalidScoreException) {
        println("カスタム例外: ${e.message}")
    }
}

カスタム例外: スコアは0から100の間でなければなりません

5. throwとreturnの違い

5. throwとreturnの違い
5. throwとreturnの違い

returnは関数の処理を終了して呼び出し元に戻りますが、throwは例外を発生させて通常の処理の流れを完全に中断します。throwを実行すると、現在の関数だけでなく、呼び出し元まで影響が及びます。

6. Kotlinでよく使う例外クラス

6. Kotlinでよく使う例外クラス
6. Kotlinでよく使う例外クラス
  • IllegalArgumentException:引数が不正なとき
  • IllegalStateException:オブジェクトの状態が不正なとき
  • IOException:入出力エラーが発生したとき
  • NullPointerException:nullを不正に参照したとき

これらの例外はKotlin/Javaで広く使われるため、状況に応じて選びましょう。

Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。

基礎からわかるKotlinをAmazonで見る

※ Amazon広告リンク

7. 初心者が覚えておきたいポイント

7. 初心者が覚えておきたいポイント
7. 初心者が覚えておきたいポイント
  • throw文は意図的に例外を発生させるための命令
  • 例外は必ずExceptionやそのサブクラスのインスタンス
  • throwを使うと処理が途中で終了し、例外が呼び出し元に伝わる
  • カスタム例外でエラー内容をわかりやすくできる
関連セミナーのご案内

【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分

「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。

本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。

具体的な体験内容と環境

【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。

【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。

この60分で得られる3つの体験

1. 自分のパソコンが「開発基地」に

プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。

2. プログラミングの「仕組み」がスッキリ

「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。

3. 「読みやすい」から「直せる」へ

Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。

※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。

セミナー画像

Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のVSCode開発環境構築完全ガイド!初心者でもわかる拡張機能と設定方法
New2
Kotlin
Kotlinの文字列を1文字ずつ処理する方法!for文とforEachの使い方を初心者向けに解説
New3
Kotlin
Kotlinの文字列比較の方法を徹底解説!==とcompareToの使い方を初心者向けにわかりやすく紹介
New4
Kotlin
Kotlinのrepeatメソッドの使い方を完全解説!初心者でもわかる文字列の繰り返し処理
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Kotlinでテキスト表示・編集!初心者でもわかるTextViewとEditTextの使い方
No.4
Java&Spring記事人気No4
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.5
Java&Spring記事人気No5
Kotlin
Kotlin Multiplatformライブラリの活用例と導入方法を初心者向けに解説!Android・iOS・Webを1つのコードで開発
No.6
Java&Spring記事人気No6
Kotlin
Kotlinで定数を定義する方法!変更されない変数の書き方と命名ルール
No.7
Java&Spring記事人気No7
Go言語
Go言語のクリーンアーキテクチャの基本概念と実装例!初心者でもわかる設計パターン完全ガイド
No.8
Java&Spring記事人気No8
Go言語
Go言語でリダイレクト処理を行う方法(http.Redirect)を初心者向けに解説