开发者

Should the include guards be unique even between namespaces?

开发者 https://www.devze.com 2023-02-14 22:49 出处:网络
I am using same class name in two namespaces, say A and B. Should the include guards be unique while declaring the classes with diffe开发者_运维技巧rent namespaces too?

I am using same class name in two namespaces, say A and B. Should the include guards be unique while declaring the classes with diffe开发者_运维技巧rent namespaces too?

I mean can't there be two files names AFile.h (in different directories) with same include guards and declaring different namespaces?

 //File 1:

 #ifndef AFILE_H 

 #define AFILE_H

 namespace A { 

   class CAFile {...

   }; 

 };

 #endif

//File 2:

 #ifndef AFILE_H 

 #define AFILE_H

 namespace B { 

   class CAFile {...

   }; 

 };

 #endif


Your guards need to be different if some code (directly or indirectly) needs to see both A::CAFile and B::CAfile.

The include guards are dealt with by the preprocessor, that has no knowledge at all of classes (let alone namespaces). If both these files are included when processing a c++ file, and they have the same header guards, only one of the declarations will remain in the preprocessed source that the compiler will see.

Look at things like Boost files, they have some conventions for the header guards (if I remember correctly).


Include guards only affect the preprocessor and the preprocessor doesn't know C++ and completely ignores namespaces. So guards should be unique to a file, not to a namespace.


In short, it's probably a good idea. Here is how the GCC does their's...

#ifndef _GLIBCXX_VECTOR
#define _GLIBCXX_VECTOR 1

I don't know about using a namespace per say but the include guard should be unique to your packaged interface (which could all be within one namespace or spread across many).


Personally, I've been using #pragma once because it's supported on the compilers I care about and you can avoid the kind of problems you mention here. If you want to use #include guards, then you may need to be clever about it. Otherwise #includeing Foo/header.h may not work because you already #included Bar/header.h.

I don't agree with the style guide in other cases, but Google recommends <PROJECT>_<PATH>_<FILE>_H_. Although that does mean that if you copy files around to different paths you're going to have to update the #include guard.

0

精彩评论

暂无评论...
验证码 换一张
取 消