カテゴリ: Go言語 更新日: 2026/01/24

Go言語の関数でエラーハンドリングする基本的な方法

Go言語の関数でエラーハンドリングする基本的な方法
Go言語の関数でエラーハンドリングする基本的な方法

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

生徒

「Go言語でエラーが起きたとき、どうやって処理すればいいですか?」

先生

「Go言語では関数がエラー情報を返すことが多いので、その返り値を確認してエラー処理を行う方法が基本です。」

生徒

「エラー処理って難しそうですが、具体的にどう書けばいいんでしょう?」

先生

「今回は、Go言語での基本的なエラーハンドリングの方法を、初心者にもわかりやすく解説しますね。」

1. Go言語のエラーハンドリングとは?

1. Go言語のエラーハンドリングとは?
1. Go言語のエラーハンドリングとは?

プログラムを動かしていると、意図しない状況が発生することがあります。これが「エラー」です。例えば、存在しないファイルを開こうとしたり、数値の計算が成立しなかったりする場合など、日常的に起こり得る問題です。エラーは単なる失敗ではなく、「ここで処理が止まる可能性がある」という重要なサインだと考えると理解しやすいでしょう。

Go言語では、関数がerror型の値を返すことで「正常に処理できたかどうか」を呼び出し元に知らせます。エラーがない場合はnil、問題が発生した場合はエラー内容が入ったerrorが返ってきます。これを受け取って、プログラム側で適切に対応するのがGoの基本的なエラーハンドリングです。

初心者でも理解しやすいように、簡単なサンプルで「エラーが返ってくるとはどういうことか」を見てみましょう。


package main

import (
    "errors"
    "fmt"
)

// 単純なエラーチェックの例
func greet(name string) error {
    if name == "" {
        return errors.New("名前が空です")
    }
    fmt.Println("こんにちは,", name)
    return nil
}

func main() {
    err := greet("") // 空文字を渡してエラーを発生させる
    if err != nil {
        fmt.Println("エラーが発生しました:", err)
    }
}

この例では、引数が空だった場合にエラーを返しています。エラーをチェックすることで、予期せぬ状態を早い段階で察知して安全に処理を進めることができます。Go言語の「エラーを返して確認する」という考え方は、プログラムを安定させるためにとても重要です。

2. error型とは?

2. error型とは?
2. error型とは?

errorはGo言語で「エラーが起きたかどうか」を表すために用意された特別な型です。関数の実行がうまくいったときはnil(何も問題がない状態)になり、何かトラブルがあったときだけerror型の値が入ります。つまり、errorを見るだけで「今の処理は成功したのか、失敗したのか」を判断できる便利な仕組みです。

イメージとしては、「結果」と一緒に「メモ付きの報告書」が返ってくるようなものです。メモが空なら問題なし、何かメッセージが書いてあればエラーというイメージです。プログラム側ではこのメモ(error)を読んで、続きの処理をするかどうかを決めていきます。

実際に、errorがどのように使われるか、シンプルなサンプルで確認してみましょう。


package main

import (
    "errors"
    "fmt"
)

// 名前が空かどうかをチェックする関数
func validateName(name string) error {
    if name == "" {
        // エラーがある場合は error 型の値を返す
        return errors.New("名前が空です")
    }
    // 問題がなければ nil(エラーなし)を返す
    return nil
}

func main() {
    err := validateName("")

    // err が nil かどうかでエラーの有無を判断する
    if err != nil {
        fmt.Println("エラー発生:", err)
    } else {
        fmt.Println("問題ありません")
    }
}

この例では、validateName関数がerror型を返しています。名前が空文字ならerrors.Newでエラーを作って返し、問題なければnilを返しています。main関数側では、err != nilかどうかを調べるだけで、エラーか正常かを簡単に判断できます。このように、error型はGo言語のエラーハンドリングで中心となる、とても重要な型です。

3. 関数でエラーを返す基本形

3. 関数でエラーを返す基本形
3. 関数でエラーを返す基本形

Go言語の関数は、1つではなく複数の値を同時に返せるのが大きな特徴です。これを活かして、「処理の結果」と「エラー情報」をセットで返すのが、Go言語のエラーハンドリングでよく使われる基本パターンです。関数の定義で(結果の型, error)という形にしておくことで、「うまくいったかどうか」「失敗した理由は何か」をわかりやすく呼び出し元に伝えられます。

例えば、2つの整数を割り算する関数を考えてみましょう。数学的には当たり前でも、「0で割ってはいけない」というルールがありますよね。この「0で割ろうとした」という状況をエラーとしてerror型で返すようにすれば、安全な関数になります。


package main

import "fmt"

// 2つの整数を割り算し、結果とエラーを返す関数
func divide(a, b int) (int, error) {
    // 0で割ろうとしたらエラーを返す
    if b == 0 {
        return 0, fmt.Errorf("0で割ることはできません")
    }
    // 正常に計算できた場合は、結果と nil(エラーなし)を返す
    return a / b, nil
}

この例では、func divide(a, b int) (int, error) という定義になっており、intが「計算結果」、errorが「エラー情報」を表しています。エラーが起きたときはreturn 0, fmt.Errorf(...)のように「ダミーの結果(ここでは0)」と「エラーの内容」を一緒に返します。問題なく計算できたときはreturn a / b, nilとし、nilを返すことで「エラーはありません」という意味になります。

このように、関数の戻り値にerrorを含める書き方を覚えておくと、Go言語の標準ライブラリと同じスタイルでエラーハンドリングが書けるようになります。次の章では、このdivide関数を実際に呼び出して、返ってきたerrorをどのようにチェックするのかを見ていきます。

4. エラーハンドリングの基本的な使い方

4. エラーハンドリングの基本的な使い方
4. エラーハンドリングの基本的な使い方

実際にこの関数を呼び出して、エラーがあるか確認する方法はこちらです。


result, err := divide(10, 0)
if err != nil {
    fmt.Println("エラー:", err)
    // エラーがあったので処理を中止したり、別の処理をしたりします
} else {
    fmt.Println("計算結果:", result)
}

ここでは、err != nilという条件でエラーがあるかどうかを調べています。
エラーがあればエラーメッセージを表示し、なければ計算結果を表示します。

5. エラーハンドリングのポイント

5. エラーハンドリングのポイント
5. エラーハンドリングのポイント
  • 関数がerrorを返す場合は必ずエラーをチェックする
  • err != nilでエラーの有無を確認する
  • エラー時の処理を分けて書くことで、予期せぬ動作を防げる

エラー処理を書くことで、プログラムの安全性や信頼性が上がります。

6. 実際にファイルを読み込む例でエラー処理を使う

6. 実際にファイルを読み込む例でエラー処理を使う
6. 実際にファイルを読み込む例でエラー処理を使う

ファイルを開く処理はエラーが起きやすいので、エラーハンドリングが重要です。


import (
    "fmt"
    "os"
)

func readFile(filename string) error {
    file, err := os.Open(filename)
    if err != nil {
        return err
    }
    defer file.Close()

    // ファイルの読み込み処理(省略)
    fmt.Println("ファイルを開きました:", filename)
    return nil
}

func main() {
    err := readFile("sample.txt")
    if err != nil {
        fmt.Println("ファイルを開くときにエラーが発生しました:", err)
    } else {
        fmt.Println("ファイルの読み込みに成功しました")
    }
}

この例では、ファイルを開くos.Open関数の返すエラーをreadFile関数で受け取り、さらに呼び出し元で処理しています。

7. エラーを自分で作る方法

7. エラーを自分で作る方法
7. エラーを自分で作る方法

時には、自分でエラーを作って返すこともあります。fmt.Errorfを使うと簡単です。


import "fmt"

func checkAge(age int) error {
    if age < 0 {
        return fmt.Errorf("年齢は0以上でなければなりません")
    }
    return nil
}

この関数は、年齢がマイナスならエラーを返します。
エラーがなければnilを返します。

8. Go言語のエラーハンドリングについて

8. Go言語のエラーハンドリングについて
8. Go言語のエラーハンドリングについて

Go言語のエラーハンドリングは、error型を返して確認しながら進めるのが基本です。
エラーを無視せず、必ずチェックすることが良いプログラムを書くコツです。

まとめ

まとめ
まとめ

Go言語の関数でエラーを扱う基本的な方法を学んできた内容を振り返ると、日常的なプログラムの中でどのように安全に処理を進めるかという点がとても大切であることがよく分かります。関数が返すerror型の値を丁寧に確認することで、意図しない動作を防ぎ、より信頼性の高いコードを書くことができます。特にGo言語では例外処理のような仕組みを使わず、返り値を使ってエラーを伝える明確なスタイルが採用されているため、プログラムの流れが分かりやすく管理しやすいという特徴があります。この特徴は初心者にとって最初は少し不思議に感じられるかもしれませんが、慣れてくると非常に扱いやすく、読みやすいコードを自然に書けるようになります。 また、実際の活用例として、ファイル操作や計算処理など日常的な操作においてエラーを返す関数が多く存在するため、エラーハンドリングを正しく行うことは必須です。たとえばファイルが存在しない場合や、ネットワーク通信に問題がある場合など、予測できない事態がいくらでも起こり得ます。こうした場面でerror型をチェックして適切に対応することで、ユーザーに分かりやすいメッセージを返したり、処理を安全に停止したりと、柔軟な制御が可能になります。特に複数のエラーを段階的に処理していくような大きなアプリケーションでは、error型を中心に据えた設計がプログラム全体の品質にも大きく関わってきます。 さらに、fmt.Errorfを使って自分でエラーを作る方法も重要なポイントでした。自作のエラーを返すことで関数の利用者に「どこで」「何が」問題だったのかを具体的に伝えることができます。これは保守性の観点でも非常に役に立ち、問題を素早く特定して修正できるようになります。Go言語はシンプルな文法でありながら、エラーメッセージを工夫することで細やかな情報を伝えられるという柔軟性があるため、初学者でも自然と扱い方が身につけやすい点も魅力のひとつです。 実際のプログラム全体を通して、エラー処理の基本形をしっかり理解しておくことで、複雑な処理にも応用が利くようになります。そのためには、関数の返り値を常に丁寧に確認し、エラー発生時にどのような対応をするべきかを明確に決めておくことが大切です。特にGo言語のコードは読みやすさや保守性を重視して書かれることが多いため、エラー処理が統一されていると全体として洗練されたコードになります。これらを意識してコードを書く習慣を身につけておくと、今後より高度なプログラミングに進んだ際にも役立つはずです。

サンプルコードで振り返る基本の形

ここでは学んだ内容を思い出すために、エラーを返す関数の基本形をもう一度整理しておきます。どんなプログラムでもまずはこの形を押さえておくと、自然と安全なコードが書けるようになります。


package main

import (
    "fmt"
)

func safeDivide(a, b int) (int, error) {
    if b == 0 {
        return 0, fmt.Errorf("0では割れません")
    }
    return a / b, nil
}

func main() {
    result, err := safeDivide(20, 0)
    if err != nil {
        fmt.Println("エラー内容:", err)
        return
    }
    fmt.Println("計算結果:", result)
}

このように返り値とエラーを組み合わせることは、Go言語では非常に一般的であり、どのような処理にも応用できます。ファイル操作、ネットワーク処理、データベース接続など、さまざまな場面でこの形が登場するため、まずは「返ってくるエラーを必ず確認する」という習慣を身につけることが大切です。また、エラーが発生した際のメッセージの書き方や処理の分岐も工夫することで、読みやすく明確なコードを作ることができます。

先生と生徒の振り返り会話

生徒

「先生、今日の内容を振り返ると、Go言語ではエラーを返して確認する方法がとても大事なんですね。最初はエラーって難しい印象でしたけど、やってみると意外とシンプルでした。」

先生

「その通りです。Go言語のエラー処理は流れが分かりやすくて、とても合理的なんです。エラーが返ってきたら必ず確認する、という基本さえ守っていれば、どんな処理でも安定して書けるようになりますよ。」

生徒

「自分でエラーを作って返す方法も面白かったです。これなら関数の利用者に詳しい情報を伝えられますね。」

先生

「そうですね。エラーメッセージを工夫することで、プログラムの品質も大きく上がります。これからネットワークやファイル処理など、さらに複雑な学習に進んだときにも役に立つので、今回の内容はとても重要ですよ。」

生徒

「はい!しっかり復習しておきます!」

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

この記事を読んだ人からの質問

この記事を読んだ人からの質問
この記事を読んだ人からの質問

プログラミング初心者からのよくある疑問/質問を解決します

Go言語のエラーハンドリングとは何ですか?どんなときに使いますか?

Go言語のエラーハンドリングとは、関数から返ってくるerror型の値を使って、プログラム中に発生したエラーを検出し、適切に処理する仕組みのことです。たとえばファイルが存在しない場合や、0で割ろうとしたときなどに使われます。
関連セミナーのご案内

【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導

「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。

本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。

具体的な開発内容と環境

【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。

【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。

この60分で得られる3つの理解

1. 環境構築の完全な理解

「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。

2. Go言語の基本構造(変数・型)

データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。

3. 読みやすいコードの書き方

ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。

※本講座は、将来的にバックエンドエンジニアクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。

セミナー画像

初めてのGo言語を一緒に学びましょう!

カテゴリの一覧へ
新着記事
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のログ出力方法を完全ガイド!LogcatとTimberでトラブルシューティング