カテゴリ: Kotlin 更新日: 2026/03/09

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. 基本的な使用例

3. 基本的な使用例
3. 基本的な使用例

fun checkAge(age: Int) {
    if (age < 0) {
        throw IllegalArgumentException("年齢は0以上でなければなりません")
    }
    println("年齢は $age 歳です")
}

fun main() {
    try {
        checkAge(-5)
    } catch (e: IllegalArgumentException) {
        println("エラーが発生: ${e.message}")
    }
}

エラーが発生: 年齢は0以上でなければなりません

この例では、年齢が負の値だった場合にIllegalArgumentExceptionthrowしています。

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言語のwhile的なforループの使い方!条件式ループの基本を解説
New2
Go言語
Go言語プログラムの実行方法まとめ!VSCode・ターミナルでの実行手順を解説
New3
Swift
Swift意味とは?プログラミング言語・金融・鳥の違いを徹底解説
New4
Swift
Swift 戻り値の扱い方と複数戻り値の返し方|初心者でも分かる関数の基本
人気記事
No.1
Java&Spring記事人気No1
Go言語
Go言語でリダイレクト処理を行う方法(http.Redirect)を初心者向けに解説
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.4
Java&Spring記事人気No4
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.5
Java&Spring記事人気No5
Go言語
Go言語のgo.modファイル完全ガイド!初心者でもわかる仕組みと書き方
No.6
Java&Spring記事人気No6
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.7
Java&Spring記事人気No7
Go言語
Go言語で条件式を1行で書くコツ!三項演算子の代替と短縮記法
No.8
Java&Spring記事人気No8
Kotlin
Kotlinの演算子一覧と使い方!算術・比較・論理演算子の基本を解説