本文介绍了为什么使用命名空间X;不允许在class / struct级别内部?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
class C {
using namespace std; // error
};
namespace N {
using namespace std; // ok
}
int main () {
using namespace std; // ok
}
编辑:想知道动机后面。
推荐答案
我不知道,但我的猜测是,允许这个在类范围可能会导致混乱: / p>
I don't know exactly, but my guess is that allowing this at class scope could cause confusion:
namespace Hello
{
typedef int World;
}
class Blah
{
using namespace Hello;
public:
World DoSomething();
}
//Should this be just World or Hello::World ?
World Blah::DoSomething()
{
//Is the using namespace valid in here?
}
由于没有明显的方法这样做,标准只是说你可以't。
Since there is no obvious way of doing this, the standard just says you can't.
现在,当我们在说命名空间范围时,这不会引起混淆:
Now, the reason this is less confusing when we're talking namespace scopes:
namespace Hello
{
typedef int World;
}
namespace Other
{
using namespace Hello;
World DoSomething();
}
//We are outside of any namespace, so we have to fully qualify everything. Therefore either of these are correct:
//Hello was imported into Other, so everything that was in Hello is also in Other. Therefore this is okay:
Other::World Other::DoSomething()
{
//We're outside of a namespace; obviously the using namespace doesn't apply here.
//EDIT: Apparently I was wrong about that... see comments.
}
//The original type was Hello::World, so this is okay too.
Hello::World Other::DoSomething()
{
//Ditto
}
namespace Other
{
//namespace Hello has been imported into Other, and we are inside Other, so therefore we never need to qualify anything from Hello.
//Therefore this is unambiguiously right
World DoSomething()
{
//We're inside the namespace, obviously the using namespace does apply here.
}
}
这篇关于为什么使用命名空间X;不允许在class / struct级别内部?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!