我在初始化列表中有很多命名空间用法,并希望使用 using namespace 来减少详细程度。但是,初始化列表超出了构造函数括号的范围,因此我必须将使用置于构造函数之外,并使用它污染文件的其余部分。有没有办法根据需要调整使用范围?而不是:
MyClass::MyClass() :
m_one(nsConstants::ONE),
m_two(nsConstants::TWO),
m_three(nsConstants::THREE)
{}
我想:
MyClass::MyClass() :
using namespace nsConstants;
m_one(ONE),
m_two(TWO),
m_three(THREE)
{}
_
答案 0 :(得分:4)
你做不到。该标准提供了一些不太好的选择:
// The stuff you want to use.
namespace foo { namespace bar {
class Frob {};
} }
现在,从 污染最少到污染最严重 。
typedef
可以在类定义的private
部分中编写该别名:
// I)
class Schwarzschild {
typedef foo::bar::Frob FbFrob;
public: Schwarzschild () : a(FbFrob()), b(FbFrob()) {}
private: FbFrob a,b,c;
};
但你也可以在全球范围内使用它,但有机会重命名它:
// II)
class Schwarzschild {
public: Schwarzschild ();
private: foo::bar::Frob a,b,c;
};
// cxx-file
typedef foo::bar::Frob FbFrob;
Scharzschild::Scharzschild() : a(FbFrob()) {}
您还可以为命名空间添加别名:
// III)
namespace fb = foo::bar;
class Planck {
public: Planck () : a(fb::Frob()), b(fb::Frob()) {}
private: fb::Frob a,b,c;
};
或者您可以从其他名称空间中挑选符号,但不利于您的Frob
可能会与您的翻译单元中的另一个Frob
发生冲突:
// IV)
using foo::bar::Frob;
class Mach {
public: Mach () : a(Frob()), b(Frob()) {}
private: Frob a,b,c;
};
为了完整起见,污染最严重的解决方案是using namespace
。
// V)
using namespace foo::bar;
class Newton {
public: Newton () : a(Frob()), b(Frob()) {}
private: Frob a,b,c;
};
请注意,III,IV和V也可以限制在您的cxx文件中,就像在Schwarzschild示例中一样。
答案 1 :(得分:0)
这显然是不可能的。在C ++中不存在类似“本地使用”的东西。因此,您必须坚持使用范围运算符或使用using
。