HEXA BLOG
ヘキサブログ
プログラム
コメント文の重要性
こんにちは。ザンギエフ大好き、平尾です。
すごく暖かくなったと思ったら、急に寒さが戻ってきました
寒暖の差が激しいので体調を崩さないか心配です。
皆様もお気をつけください。
今回はプログラムを学んでいる学生に向けて、コメント文の話をしたいと思います。
コメント文は実際に処理として組み込まれるわけではないですが、大変重要なものです。
プログラマとして仕事をしている方なら、よりその重要性を感じているのではないでしょうか。
コメント文が役に立つ点としては以下のようなことが考えられます。
処理の流れや要約を簡単に知ることができる
制作者の意図を知ることができる
今後のためのメモを残せる
当たり前なことばかりで申し訳ありません
では順番に説明していきます。
:
処理の流れや要約を簡単に知ることができる。ごく普通の理由です。
ソースコードを見れば全ての処理を知ることはできます。
しかし処理を理解するのに必要なのは、まずはおおまかなアルゴリズムだったり、処理の流れだったりします。
そんなときはコンピュータに実行させる単位で見るより、人間に分かる単位で書かれたものを見る方が圧倒的に効率がいいわけです。
自分が作ったものでも、あまりにも前のソースだと忘れたりしますが、そんなときも役に立ちます。
:
制作者の意図を残せるというのも、また大切な要素です。
例えば次のような処理があったとしましょう。
switch( mode ) { case MODE_INITIALIZE: initialize(); case MODE_UPDATE: update(); break; }
最初のケースの中、initialize(); の後にbreakが入っていないのはバグじゃないか?と思いますよね。
でも以下のように一文入っているだけで、
switch( mode ) { case MODE_INITIALIZE: initialize(); // breakせずに引き続き更新処理を行います case MODE_UPDATE: update(); break; }
ああ、これは意図された処理なんだ、と理解できます。
ソースコードだけではよく分からない微妙なニュアンスも残せるわけです。
:
今後のためにメモを残せるという項目についてです。
自分でルール付けをして書いておけば、後から行う最適化やリファクタリングのときに便利です。
例えば、今後するべきことを書いておく場合。
// TODO:とりあえずバブルソートで実装。今は問題無いが、 // 処理が重くなってきたときに別のソートに置き換える必要あり。
といった風に書いておけば、TODO:でgrepして見つけることが出来ます。
こうやって書いておく癖をつけておけば、後でやることを忘れていた、なんてことが減ると思います。
:
ただ、何でもかんでもコメントさえ書けばいいというわけではありません。
例えば次のようなものはNGです。
// 登録個数ループ。 for( int i=0; i<count; ++i ) { : : }
コードを見たまま書いているようなコメントではあまり意味がありません。
今まで説明してきたように、処理の流れや意図が分かるように書く必要があります。
次のような感じです。
// 登録されているものから検索。一番始めに見つけたデータを使用する。 for( int i=0; i<count; ++i ) { : : }
これならば中で何をしたいのかがよく分かると思います。
コメント文という、プログラムにおける初歩の話をしましたが、少しはお役に立てたでしょうか?
役に立つようでしたら、これからもこういった基礎的な話などを書いていきたいと思います。
P.S.
会社説明会のエントリー状況がとても好調で、3/25の東京会場は残りわずかとなっています。
弊社に興味のある方はお早めのエントリーをお願い致します!
CATEGORY
- about ヘキサ (166)
- 部活動 (6)
- CG (18)
- プロジェクトマネジメント (1)
- 研修 (5)
- 美学 (1)
- いいモノづくり道 (230)
- 採用 -お役立ち情報も- (149)
- プログラム (188)
- デザイン (99)
- ゲーム (274)
- 日記 (1,104)
- 書籍紹介 (113)
- その他 (875)
- 就活アドバイス (20)
- ラーメン (3)
- ライフハック (25)
- イベント紹介 (10)
- 料理 (23)
- TIPS (7)
- 怖い話 (3)
- サウンド (5)
- 子育て (1)
- 筋トレ (1)
- 商品紹介 (21)
- アプリ紹介 (31)
- ソフトウェア紹介 (33)
- ガジェット紹介 (12)
- サイト紹介 (10)
- 研究・開発 (34)
- 回路図 (4)
- アナログゲーム (40)
- 交流会 (21)
- 報告会 (3)
- インフラ (25)
- グリとブラン (6)
- カメラ (9)
- クラフト (27)
- 部活 (14)
- 画伯 (15)
- カレー (6)
- 音楽(洋楽) (6)
- 映画・舞台鑑賞 (43)
- 飼育 (5)
- いぬ (8)
- ねこ (19)
ARCHIVE
- 2024年
- 2023年
- 2022年
- 2021年
- 2020年
- 2019年
- 2018年
- 2017年
- 2016年
- 2015年
- 2014年
- 2013年
- 2012年
- 2011年
- 2010年
- 2009年
- 2008年
- 2007年