はじめに
前回は、Go言語のインストールと、LiteIDEのインストールを行い環境を整えました。
今回は、LiteIDEの使用の簡単な使い方を兼ねて、伝統のHelloWorldを標準出力に出力し、そこからわかる事を学習したいと思います。
プロジェクトの作成
「新規プロジェクト/ファイル」ダイアログが表示されます。
デフォルトのソースファイルパス「GOPATH」(「C:\Users[ユーザ名]\go\src」)、テンプレートは「Go1 Command Project」を選択します。名前は「HelloWorld」とし、「OK」ボタンを押下します。
このプロジェクトが作成される場所は、[GOPATH]\src\[プロジェクト名前]
になります。
プロジェクトが作成された事と、読み込むかの確認メッセージが表示されますので、「はい」ボタンを押下します。
プロジェクトが生成されて、最初の雛形として今回の目的であるHelloWorldを出力するプログラムが作成されます。
LiteIDEの左枠にある。「1:フォルダ」をクリックします。「HelloWorld」フォルダが表示されますので、矢印(「>」)をクリックして入ってるファイルが表示します。2つのファイルが存在しています。詳細は、それぞれのファイルは後ほど確認していきます。
- main.go ソースファイル
- doc.go ドキュメントソースファイル
ビルド
プロジェクトを作成した時点で、「HelloWorld」が出力できる状態になっているので、これを使ってLiteIDEの動かし方を学習します。
最初に行うのはビルドです。
ビルドが完了すると画面下部にビルドの状態が表示されます。今回のビルドは「成功」と表示されています。
また、先程表示したフォルダ内に「HelloWorld.exe」が作成されます。
実行
実行結果が画面下部に表示されます。
今回は「Hello World!」が表示されています、成功です。
デバッグ
LiteIDEのデバックモードを試したいと思います。
準備
デバッカーを変更します。「デバッグ」メニューから「debugger/delve」を選択します。(初期の状態は「debugger/gdb」が選択されています。「gdb」が既に入ってる環境であれば「debugger/gdb」でも良さそうです。)
「debugger/delve」を選択後に、再度「デバッグ」メニューを表示すると選択状態が「debugger/gdb」から「debugger/delve」に変わっています。
デバッグモード
「デバック開始」選択すると、8行目の「func main() {」の左側に緑矢印が表示されます。これが現在の実行行になります。また、フォルダ内に「HelloWorld.debug.exe」というファイルが作成されます。
ステップ実行
実行を1行単位で進めていきます。ステップ実行は「ステップ実行(入る)」と「ステップ実行(通過)」の2種類があります。それぞれの動きを9行目の「fmt.Println("Hello World!")」で確認します。
実行行を8行目から9行目に移動させるには「デバッグ」メニューから「ステップ実行(入る)」、または「ステップ実行(通過)」のいずれかを選択します。この状態ではどちらを選択しても変わりはありません。
「ステップ実行(入る)」
実行行が9行目にある状態で、「デバッグ」メニューから「ステップ実行(入る)」を選択します。
新規に「Print.go」タブが追加され、263行目の「func Println(a ...interface{}) (n int, err error) {」に緑の矢印が移動しました。これはmain.goの9行目に記述されている「fmt.Println」関数のソースコードになります。この様に「ステップ実行(入る)」を選択した場合は、呼び出す関数のソースコードに実行行が移動します。(「Print.go」ファイルは、このプロジェクト内には存在しませんが、デフォルトでは「C:\Go\src\fmt\print.go」に存在しています。)
「デバッグ」メニューから「続行」を選択し、デバッグモードを終わらせます。
表示が再び「main.go」に戻り、実行行を表す緑の矢印もありません。
「ステップ実行(通過)」
先程と同じ様にデバッグ開始を実行しステップ実行を選択し、9行目まで進めます。
実行行が9行目にある状態で、「デバッグ」メニューから「ステップ実行(通過)」を選択します。
選択すると先程の様にタブが開くこともなく、実行行が10行目に進みます。
この2つの使い分けとしては、関数の内部に入って確認する必要がある場合はステップ実行(入る)」を、必要がなく変数の値確認だけで良い場合などは、「ステップ実行(通過)」を使用します。
ブレイクポイント
デバッグする際に1行づつ進めるやり方で、対象行まで進めても良いですが、行数が多い場合など毎回1行づつ進めて行くのは手間がかかります。そこまで特定の行にブレイクポイントを設定し、そこまで実行行を進めるやり方を取ります。
やり方は、確認したい行にカーソルを移動させ、オレンジの丸を押下します。(確認したい行、例えば変数代入を行っている箇所や、制御文の少し前にブレイクポイントを設定し、そこからステップ実行しながら確認すると効率よくデバック出来ます。)
オレンジの丸を押下するとブレイクポイントにとなりに、オレンジの丸が設定されます。
「デバッグ」メニューから「デバックを開始」し、「デバッグ」メニューから「続行」を選択します。
実行行を表す緑の矢印がブレイクポイントを設定した行に移動し、実行行が移動した事を確認出来ます。
ブレイクポイントはいくつも設定できます。またブレイクポイントが不要になった場合は、不要になった対象の行にカーソルを移動させ、オレンジの丸を押下します。
変数の値の確認
デバッグモード中は、変数の値を確認する事ができます。ソースの下にある「レコード同期」タブの隣に「変数」タブがあり、そこに必要に応じて変数と値が表示されます。(今回の例だとわかりにくいです。)
main.go ソースファイル
自動生成されたソースを見ていきたいと思います。今回自動生成されたのは下記のコードです。
// HelloWorld project main.go
package main
import (
"fmt"
)
func main() {
fmt.Println("Hello World!")
}
なお、Go言語のソースファイルの、文字コードは「UTF-8」で記述する必要があります。
詳細に関しては下記を参考にして下さい。
「The Go Programming Language Specification:Source code representation」
1行目:// HelloWorld project main.go
コメント行です。Go言語ではコメントは、「//」以降がコメントになる行コメントと、「/*」と「*/」で囲まれたは範囲がコメントになるブロックコメントの2つが使用出来ます。
// HelloWorld project main.go
通常は1行で終わるコメントは「//」、複数行に渡ってコメントを記載する場合は「/*」と「*/」を使用します。1行目を「/*」と「*/」で書き換えた場合は以下のようになります。
/* HelloWorld project main.go */
2行目:package main"
対象のソースが属するパッケージを指定します。このソースでは「main関数」(エントリーポイント)が入ってるので「mainパッケージ」になります。「main」パッケージ以外ではmain関数を定義しても、実行形式のファイルは作成されません。また、「mainパッケージ」を指定して「main」関数がない場合はエラーになります。
package main
4行目~6行目:import ~
「fmtパッケージ」をインポートしています。他のパッケージに属する関数を使用したい場合に使用します。今回は後ほどHelloWorldを標準出力に出力するため「fmtパケージ」を呼び出しています。その他の標準パッケージはThe Go Programming LanguageのPackagesを参照して下さい。
import (
"fmt"
)
復数のパッケージをインポートする場合は、下記の様に記述します。
import (
"fmt"
"strings"
)
1行で記述することも可能です。
import "fmt"
8行目、10行目:func main() ~
このプログラムのエントリーポイントになります。プログラムが呼び出された場合、最初に呼ばれる関数になります。記述は必ず「func main()」になります。
「func」は関数で有ることを宣言し、「main」は関数名になります。続く「()」は、関数の引数を表します。この場合は引数無しです。また、関数は波括弧({})でくくられた範囲が関数本体を表します。
func main() {
:
:
:
}
9行目:fmt.Println ~
パッケージ「fmt」の「Println」関数を、引数に文字列の「Hello World!」で呼び出す宣言になります。ダブルクォート「"」で囲まれた値は文字列であることを表すので、出力にダブルクォートは出力されません。
呼び出すと標準出力に「Hello World!」を出力することになります。
fmt.Println("Hello World!")
doc.go ドキュメントソースファイル
ソースファイルと同じ様に自動生成されたdoc.goファイルです。
// HelloWorld project doc.go
/*
HelloWorld document
*/
package main
ドキュメントは以下の方法で確認出来ます。
コマンドプロンプトから次のコマンドを実行します。(コマンドプロンプトは閉じないで下さい。)
>godoc -http=:6060
ブラウザから「http://localhost:6060/pkg/」を開くと、パッケージ一覧に作成したパッケージが表示され、該当のドキュメントのファイルの内容が表示されます。
詳細ページでは「main.go」のコメントも合わせて表示されます。
終わりに
自動生成されたソースを動かして、これから学習して行く下地が出来たかなと思います。
今後は関数や変数、制御文について学習していきたいと思います。パッケージに関するドキュメントはThe Go Programming LanguageのPackagesを見て、どういう事ができるかある程度知っておく必要がありそうです。また、プログラミングする際に変数名や関数名などの参考にしたいと思います。
最後まで読んで頂きありがとうございました。勘違いなどあればご指摘、ご意見頂けると助かります。