关于using编译指令和using声明,虽然方便了程序员,但却增加了二义性:
在在全局声明区域使用using编译指令,将使该名称空间的名称全局可用,例如:
#include<iostream>
using namespace jack; 则Jack中的所有变量都可用,加入Jack中有变量hill,如果此时代码中还有一个变量hill,就会产生二义性;
另外,还有这种情况也会产生二义性:
namespace jack{double hill;}
namespace jill{double hill;}
int main()
{
using jack::hill;
using jill::hill; //using声明
hill=3; //此时就会产生二义性,到底此处的hill是Jack的还是jill的?
}
但是如果使用作用域解析运算符,就不会有这种麻烦:
jack::hill=1;
jill::hill=2;
2:注意,假设名称空间和声明区域定义了相同的名称。如果试图使用using声明将名称空间的名称导入该声明区域,则这两个名称就会发生冲突,从而出错。如果使用using编译指令将该名称空间的名称导入该声明区域,则局部变量将隐藏名称空间版本。一般来说,使用using声明比使用using编译指令更安全,这是由于他只导入指定的名称,如果该名称与局部名称发生冲突,编译器将发出指令,。using编译指令导入所有名称,包括可能并不需要的名称,如果与局部名称发生冲突,局保护名称将覆盖名称空间版本。
#include<iostream>
namespace A
{
char name='A';
}
char name='G'; //全局变量
int main()
{
using namespace A;
//using A::name;
char name='M'; //局部变量,此时,他隐藏了全局变量
std::cout<<name<<std::endl; //使用局部变量
std::cout<<::name<<std::endl; //使用全局变量
std::cout<<A::name<<std::endl; //使用名称空间A中的变量
std::cin.get();
return 0;
}