カテゴリ: Go言語 更新日: 2026/02/20

Go言語の関数をモジュール化して管理する方法

Go言語の関数をモジュール化して管理する方法
Go言語の関数をモジュール化して管理する方法

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

生徒

「先生、Go言語で作った関数を整理して管理する方法ってありますか?」

先生

「いい質問ですね。Go言語では、関数をファイルごとに分けて、モジュール化して管理するのが一般的です。」

生徒

「それってどうやってやるんですか?フォルダとか使うんですか?」

先生

「はい、フォルダやパッケージを使って関数を整理できますよ。実際の手順を詳しく見ていきましょう。」

1. モジュール化とは?

1. モジュール化とは?
1. モジュール化とは?

モジュール化とは、プログラムを役割ごとに分けて管理しやすくする考え方です。
例えば、料理の「材料を切る」「炒める」「盛り付ける」を一つのボウルに全部入れてしまうと混乱しますよね。プログラミングでも同じで、関数を一つのファイルに詰め込みすぎると読みにくくなり、修正もしづらくなります。
Go言語では、関連する処理をひとまとめにして、ファイルやフォルダ(パッケージ)ごとに整理できます。例えば、計算に関する処理だけを集めたファイル、文字列を扱う処理だけを集めたファイル、というように分類するイメージです。

こうして役割を分けておくと、「この計算の処理はどこだろう?」と探しやすくなり、後から機能を足したり修正したりする場面でもスムーズです。特に、プログラムが大きくなるほどモジュール化の効果が大きくなります。

生徒

「なるほど…。でも、関数がたくさん増えてきたらどうしよう、って思ってました。」

先生

「まさにそこでモジュール化が役に立ちます。これはプログラミング初心者ほど覚えておくと便利なんです。他の人が見てもわかりやすいし、自分が後で見返したときにも迷わずに済みます。」

生徒

「整理整頓みたいなものなんですね!ファイルを分けるだけでプログラムがきれいになるなら、すぐにでもやってみたいです。」

先生

「その通りです。まずは、『同じ役割の処理は同じ場所にまとめる』という感覚を身につけるのが第一歩ですね。」

2. ファイル分割で関数を整理する

2. ファイル分割で関数を整理する
2. ファイル分割で関数を整理する

まずは、小さな単位から関数を分けてみましょう。ポイントは役割ごとにファイルを分けることと、同じフォルダ内のファイルは同じpackage名にそろえることです。こうしておくと、Go言語のビルドや実行が迷わず動き、後から読む人にも意図が伝わります。以下は「計算だけ」をまとめたファイルの例です。

calc.go ファイル(同じフォルダ内):


package myutil

// 足し算だけを担当する小さな関数
func Add(a int, b int) int {
    return a + b
}

// 役割が近いので同じファイルに置いてもOK
func Sub(a int, b int) int {
    return a - b
}

このとき、package myutilと書くことで、このファイルはmyutilという名前のパッケージ(モジュールの中の単位)に属します。関数を増やしたくなったら、同じフォルダにファイルを追加し、同じpackage myutilを宣言すればまとめて管理できます。例えば、平均値の計算だけを別ファイルに分けたいときは次のようにします。

avg.go ファイル(同じフォルダ内):


package myutil

func Avg(a, b int) int {
    return (a + b) / 2
}

このように「計算系(Add/Sub/Avg)」をひとまとめにしておけば、目的の関数を探しやすく、保守も簡単です。ファイル分割のコツは、迷ったら“用途の近さ”でグループ化すること。後続の節で触れるように、他のパッケージから使いたい関数は先頭を大文字で始めておくと、再利用にもつながります。

3. 別ファイルから関数を呼び出す

3. 別ファイルから関数を呼び出す
3. 別ファイルから関数を呼び出す

ここでは、前節で同じフォルダに用意したmyutilパッケージの関数を、エントリーポイントのmain.goから呼び出す流れを確認します。大事なポイントは、importに書くパスがプロジェクトのモジュール名+パッケージ名になることと、公開したい関数は先頭を大文字にしておくことです。次のコードは最小構成の実例です。


package main

import (
    "fmt"
    // モジュール名が your_project の場合
    "your_project/myutil"
)

func main() {
    // パッケージ名.関数名 で呼び出す
    result := myutil.Add(3, 4)
    fmt.Println("計算結果:", result)
}

import "your_project/myutil"your_projectは、プロジェクトのモジュール名に置き換えてください(例えばgo mod init your_projectとした名前)。フォルダ名だけを書いても解決できないので注意しましょう。また、読みやすさのために別名インポートを使うこともできます。


package main

import (
    "fmt"
    util "your_project/myutil" // パッケージに短い別名を付ける
)

func main() {
    fmt.Println(util.Sub(10, 6))
}

呼び出し側では、パッケージ名.関数名の形で使います。もしビルド時に「見つからない」というエラーが出るときは、importのパスと、myutil側のpackage名が一致しているか、そして関数名が大文字で公開されているかを見直すと解決しやすくなります。動作確認は、プロジェクトのルートでgo run .を実行すればOKです。

4. ディレクトリ構成を確認しよう

4. ディレクトリ構成を確認しよう
4. ディレクトリ構成を確認しよう

関数をモジュール化して整理するには、ファイルやフォルダ(ディレクトリ)を正しく構成する必要があります。
例えば、次のような構成がよく使われます。


    your_project/
    ├── main.go
    └── myutil/
        └── calc.go

このようにフォルダを分けることで、複数の関数を整理しやすくなります。

5. モジュール化するメリット

5. モジュール化するメリット
5. モジュール化するメリット
  • コードが読みやすくなる
  • 他の人と分担して作業しやすくなる
  • バグを見つけやすくなる
  • 再利用しやすくなる

関数をモジュール化することで、整理整頓されたプログラムになります。これは、小学校の道具箱をきちんと仕切るようなイメージです。

6. 大文字と小文字で使える範囲が変わる

6. 大文字と小文字で使える範囲が変わる
6. 大文字と小文字で使える範囲が変わる

Go言語では、関数名の先頭が大文字小文字かで「公開されるかどうか」が決まります。
Addのように大文字で始まる関数は、他のパッケージから使えます。
addのように小文字で始まる関数は、そのパッケージの中でしか使えません。

7. Go Modules(ゴーモジュール)とは?

7. Go Modules(ゴーモジュール)とは?
7. Go Modules(ゴーモジュール)とは?

Go Modulesとは、Go言語のプロジェクトを管理する仕組みです。
go mod initというコマンドを使って、プロジェクトに名前をつけると、モジュールとして使えるようになります。


go mod init your_project

この名前を使って、import "your_project/myutil"のように他のパッケージを読み込めます。

まとめ

まとめ
まとめ

ここまで、Go言語で関数をモジュール化して管理する基本的な流れを紹介しました。最初は少しむずかしく見えますが、実際に手を動かしてみると、意外とシンプルで便利な仕組みだと実感できるはずです。特に、関数をひとつのファイルにまとめるのではなく、役割ごとに整理して分割することは、中規模以上のプログラムではとても大事になります。どんなに小さなアプリでも、あとから機能を増やしたいときや、他の人と共同で作業したいときに、フォルダやパッケージで整理されていると見通しが良くなります。 さらに、Go言語では「大文字で始まる関数は公開」「小文字は内部専用」というルールも非常に分かりやすい特徴です。このルールのおかげで、意図せず外側から呼び出されてしまう危険が減り、より安全にコードを整理できます。しかも、この仕組みは特別な設定なしにGo言語が自動で判断してくれるため、初心者でも自然に使える点が魅力です。 また、「Go Modules(ゴーモジュール)」を使えば、プロジェクトの名前や、どのパッケージを使っているかといった情報を自動で整理してくれます。これがあるおかげで、複数のフォルダに分けた関数を読み込むときにも迷わず記述できますし、パソコンを変えたり、他の開発者がコードを持っていったりしても、簡単に同じ環境を再現できます。

実際にモジュール化した小さなサンプル

ほんとうに簡単な例ですが、モジュール化の流れをひとつにまとめてみましょう。


your_project/
├── main.go
└── myutil/
    └── hello.go

hello.go


package myutil

func Hello(name string) string {
    return "こんにちは、" + name + "さん!"
}

main.go


package main

import (
    "fmt"
    "your_project/myutil"
)

func main() {
    message := myutil.Hello("太郎")
    fmt.Println(message)
}

たったこれだけですが、フォルダを分けて関数を整理できています。hello.goの中で関数名が大文字で始まっているので、main.goから呼び出すことができます。もし関数名がhelloという小文字で始まる名前だった場合は、外のファイルから呼び出すことができません。同じGo言語のコードでも、書き方ひとつで役割や公開範囲が変わる、というわかりやすい例になっています。

プログラミングを学びはじめたばかりの人は「とりあえず1つのファイルに全部書けば動くし、それでいいのでは?」と思うことがあります。たしかに、短いサンプルであればそれでも問題ないこともあります。しかし、処理が増えたり、複数人で開発したり、あとから修正を重ねていくと、ファイルがどんどん大きくなり、読みづらくなり、間違いも増えてしまいます。そうならないように、最初から関数をモジュール化して整理する習慣を身につけておくと、あとで大きな差になります。 初めてのうちは、ただフォルダを作ってファイルを分けるだけでも十分な練習になります。まずは「myutil」「tools」「calc」など、自分で分かりやすいフォルダ名をつけて、小さな関数を入れてみてください。うまく分類できるようになると、コードが驚くほど読みやすくなり、ひとつひとつの処理を見つけやすくなります。

また、モジュール化はプログラムの品質にも深い関係があります。例えば、計算する処理と文字を表示する処理が混ざっていると、どこを修正すれば良いか分かりにくくなります。反対に、計算は「calc」、文字表示は「view」というように役割が分かれていれば、修正する場所を間違えることがありません。小さなアプリほど、この考え方が後で効いてきます。

プログラムが成長すればするほど、モジュール化の効果は大きくなります。はじめは少し手間に感じるかもしれませんが、慣れると自然にできるようになります。自分のコードが読みやすく整理され、エラーも少なくなり、再利用できる関数も増え、開発スピードが大きく上がります。ぜひ今日から、少しずつフォルダ分割やパッケージの整理を意識してみてください。

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

生徒

「先生、モジュール化ってただファイルを分けるだけだと思ってました。でも役割ごとに整理すると見え方が全然ちがうんですね!」

先生

「その通りです。整理されているコードは読みやすく、修正しやすく、エラーにも強いんですよ。」

生徒

「大文字と小文字で公開範囲が変わるのもおもしろいです。知らないで書いていたら、呼び出せなくて困っていたかも…。」

先生

「Go言語は、こういうわかりやすいルールがたくさんあります。今日学んだことは、どんなプログラムにも応用できますよ。」

生徒

「フォルダを分けるだけでも整理になるなら、これから小さなプログラムでもやってみます!」

先生

「それが一番良い練習です。コードは書けば書くほど上達しますから、どんどん自分の手で作ってみましょう。」

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

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

※ Amazon広告リンク

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

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

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

Go言語で関数をモジュール化するメリットは何ですか?初心者でもやったほうが良いのでしょうか?

Go言語で関数をモジュール化すると、コードが読みやすくなり、整理しやすくなり、後から修正するときにも迷いません。プログラミング初心者でも、ファイルを分けて書く習慣を早い段階で身につけると、プログラムが大きくなっても混乱しなくなるため、とても役立ちます。
関連セミナーのご案内

【超入門】ゼロから始める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でトラブルシューティング