メインコンテンツへスキップ

C++のインクルードガードの命名

·711 文字·
技術解説 C++
komori-n
著者
komori-n
目次

_ から始まる変数や __ を含む変数をマクロ定数に用いてはいけないが、世の中にはこのルールを逸脱しているコードが数多く存在するので注意が必要である。

予約語
#

c++ではいくつか識別子として使ってはいけない名前(予約語)が存在する。例えば、structint など言語機能にかかわる単語は変数名やクラス名として用いることができない事になっている。コード中でこれらの識別子が使われた場合、コンパイルに失敗するので大きな問題になる前に気づくことができる。

一方、C++では以下の識別子はコンパイラのために予め予約されているので、ユーザーが勝手に使うのは規約違反である。言語機能にかかわる単語とは違い、名前が衝突しない限りコンパイラからwarningが発せられることはないので、普段から意識していないと気づくことができない。

  • 2つ以上連続したアンダースコア __ を含む識別子
    • 例)A__B, __x
  • 「アンダースコア _ + 大文字」から始まる識別子
    • 例)_ABC
  • (global namespace限定)「アンダースコア _ + 小文字」から始まる識別子
    • 例)_abc

3番目のルールだけ少しややこしいが、global namespace以外(namespace内やローカル変数など)ではユーザー側が好きに使うことができる。

よって、以下のようなインクルードガードを書くのはC++のコードとしては正しくない。

#ifndef _INCLUDE_GUARD_HOGE_H__  // 予約語なのでダメ(!)
#define _INCLUDE_GUARD_HOGE_H__

// implementations...

#endif // _INCLUDE_GUARD_HOGE_H__

正しくは、インクルードガードには INCLUDE_GUARD_HOGE_H_ のようにルールを守った変数名をつける。さらに言えば、プロジェクト全体で変数名が被らないようにするために、”fuga/piyo/hoge.h” なら FUGA_PIYO_HOGE_H_ のようにファイルの階層に合わせた命名にしたほうが良い。

Related

3要素以上のstd::min, std::maxを取る
·156 文字
技術解説 C++ STL
C/C++でconstの位置に迷うときの考え方
·1145 文字
技術解説 C++
std::piecewise_constructの使い方(std::pair)
·610 文字
技術解説 C++