C++ 命名空间namespaceWord文档格式.docx

上传人:b****5 文档编号:19223946 上传时间:2023-01-04 格式:DOCX 页数:10 大小:18.88KB
下载 相关 举报
C++ 命名空间namespaceWord文档格式.docx_第1页
第1页 / 共10页
C++ 命名空间namespaceWord文档格式.docx_第2页
第2页 / 共10页
C++ 命名空间namespaceWord文档格式.docx_第3页
第3页 / 共10页
C++ 命名空间namespaceWord文档格式.docx_第4页
第4页 / 共10页
C++ 命名空间namespaceWord文档格式.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

C++ 命名空间namespaceWord文档格式.docx

《C++ 命名空间namespaceWord文档格式.docx》由会员分享,可在线阅读,更多相关《C++ 命名空间namespaceWord文档格式.docx(10页珍藏版)》请在冰豆网上搜索。

C++ 命名空间namespaceWord文档格式.docx

命名空间

命名空间(namespace)是一种描述逻辑分组的机制,可以将按某些标准在逻辑上属于同一个集团的声明放在同一个命名空间中。

原来C++标识符的作用域分成三级:

代码块({……},如复合语句和函数体)、类和全局。

现在,在其中的类和全局之间,标准C++又添加了命名空间这一个作用域级别。

命名空间可以是全局的,也可以位于另一个命名空间之中,但是不能位于类和代码块中。

所以,在命名空间中声明的名称(标识符),默认具有外部链接特性(除非它引用了常量)。

在所有命名空间之外,还存在一个全局命名空间,它对应于文件级的声明域。

因此,在命名空间机制中,原来的全局变量,现在被认为位于全局命名空间中。

标准C++库(不包括标准C库)中所包含的所有内容(包括常量、变量、结构、类和函数等)都被定义在命名空间std(standard标准)中了。

2)定义命名空间

有两种形式的命名空间——有名的和无名的。

命名空间的定义格式为:

(取自C++标准文档)

named-namespace-definition:

namespaceidentifier{namespace-body}

unnamed-namespace-definition:

namespace{namespace-body}

namespace-body:

declaration-seqopt

即:

(自己翻译并改写的)

有名的命名空间:

namespace命名空间名{

声明序列可选

}

无名的命名空间:

namespace{

命名空间的成员,是在命名空间定义中的花括号内声明了的名称。

可以在命名空间的定义内,定义命名空间的成员(内部定义)。

也可以只在命名空间的定义内声明成员,而在命名空间的定义之外,定义命名空间的成员(外部定义)。

命名空间成员的外部定义的格式为:

命名空间名:

:

成员名……

例如:

//out.h

namespaceOuter{//命名空间Outer的定义

inti;

//命名空间Outer的成员i的内部定义

namespaceInner{//子命名空间Inner的内部定义

voidf(){i++;

}//命名空间Inner的成员f()的内部定义,其中的i为Outer:

i

inti;

voidg(){i++;

}//命名空间Inner的成员g()的内部定义,其中的i为Inner:

voidh();

//命名空间Inner的成员h()的声明

voidf();

//命名空间Outer的成员f()的声明

//namespaceInner2;

//错误,不能声明子命名空间

}

voidOuter:

f(){i--;

}//命名空间Outer的成员f()的外部定义

Inner:

h(){i--;

}//命名空间Inner的成员h()的外部定义

//namespaceOuter:

Inner2{/*……*/}//错误,不能在外部定义子命名空间

注意:

不能在命名空间的定义中声明(另一个嵌套的)子命名空间,只能在命名空间的定义中定义子命名空间。

也不能直接使用“命名空间名:

成员名……”定义方式,为命名空间添加新成员,而必须先在命名空间的定义中添加新成员的声明。

另外,命名空间是开放的,即可以随时把新的成员名称加入到已有的命名空间之中去。

方法是,多次声明和定义同一命名空间,每次添加自己的新成员和名称。

namespaceA{

}//现在A有成员i和f()

intj;

voidg();

}//现在A有成员i、f()、j和g()

还可以用多种方法,来组合现有的命名空间,让它们为我所用。

namespaceMy_lib{

usingnamespaceHis_string;

usingnamespaceHer_vector;

usingYour_list:

List;

voidmy_f(String&

List&

);

……

usingnamespaceMy_lib;

Vector<

String>

vs[5];

List<

int>

li[10];

my_f(vs[2],li[5]);

3)使用命名空间

作用域解析运算符(:

对命名空间中成员的引用,需要使用命名空间的作用域解析运算符:

//out1.cpp

#include"

out.h"

#include<

iostream>

intmain(){

Outer:

i=0;

f();

//Outer:

i=-1;

g();

//Inner:

i=1;

h();

std:

cout<

"

Hello,World!

"

endl;

Outer:

i="

i<

 

using指令(usingnamespace)

为了省去每次调用Inner成员和标准库的函数和对象时,都要添加Outer:

和sta:

的麻烦,可以使用标准C++的using编译指令来简化对命名空间中的名称的使用。

格式为:

usingnamespace命名空间名[:

命名空间名……];

在这条语句之后,就可以直接使用该命名空间中的标识符,而不必写前面的命名空间定位部分。

因为using指令,使所指定的整个命名空间中的所有成员都直接可用。

//out2.cpp

//usingnamespaceOuter;

//编译错误,因为变量i和函数f()有名称冲突

usingnamespaceOuter:

Inner;

usingnamespacestd;

f();

f(),Outer:

i=0;

g();

g(),Inner:

h();

h(),Inner:

cout<

endl;

i<

又例如:

(.NET框架)

usingnamespaceSystem:

Drawing:

Imaging;

Window:

Forms:

Design:

Behavior;

using声明(using)

除了可以使用using编译指令(组合关键字usingnamespace)外,还可以使用using声明来简化对命名空间中的名称的使用。

using命名空间名:

[命名空间名:

……]成员名;

注意,关键字using后面并没有跟关键字namespace,而且最后必须为命名空间的成员名(而在using编译指令的最后,必须为命名空间名)。

与using指令不同的是,using声明只是把命名空间的特定成员的名称,添加该声明所在的区域中,使得该成员可以不需要采用,(多级)命名空间的作用域解析运算符来定位,而直接被使用。

但是该命名空间的其他成员,仍然需要作用域解析运算符来定位。

//out3.cpp

usingnamespaceOuter;

//注意,此处无:

Inner

//usingInner:

f;

//编译错误,因为函数f()有名称冲突

usingInner:

g;

//此处省去Outer:

,是因为Outer已经被前面的using指令作用过了

h;

Inner:

using指令与using声明的比较

可见,using编译指令和using声明,都可以简化对命名空间中名称的访问。

using指令使用后,可以一劳永逸,对整个命名空间的所有成员都有效,非常方便。

而using声明,则必须对命名空间的不同成员名称,一个一个地去声明,非常麻烦。

但是,一般来说,使用using声明会更安全。

因为,using声明只导入指定的名称,如果该名称与局部名称发生冲突,编译器会报错。

而using指令导入整个命名空间中的所有成员的名称,包括那些可能根本用不到的名称,如果其中有名称与局部名称发生冲突,则编译器并不会发出任何警告信息,而只是用局部名去自动覆盖命名空间中的同名成员。

特别是命名空间的开放性,使得一个命名空间的成员,可能分散在多个地方,程序员难以准确知道,别人到底为该命名空间添加了哪些名称。

虽然使用命名空间的方法,有多种可供选择。

但是不能贪图方便,一味使用using指令,这样就完全背离了设计命名空间的初衷,也失去了命名空间应该具有的防止名称冲突的功能。

一般情况下,对偶尔使用的命名空间成员,应该使用命名空间的作用域解析运算符来直接给名称定位。

而对一个大命名空间中的经常要使用的少数几个成员,提倡使用using声明,而不应该使用using编译指令。

只有需要反复使用同一个命名空间的许多数成员时,使用using编译指令,才被认为是可取的。

例如,如果一个程序(如上面的outi.cpp)只使用一两次cout,而且也不使用std命名空间中的其他成员,则可以使用命名空间的作用域解析运算符来直接定位。

如:

std:

又例如,如果一个程序要反复使用std命名空间中的cin、cout和cerr(如上面的outi.cpp),而不怎么使用其他std命名空间中的其他成员,则应该使用using声明而不是using指令。

usingstd:

cout;

4)命名空间的名称

命名空间别名

标准C++引入命名空间,主要是为了避免成员的名称冲突。

若果用户都给自己的命名空间取简短的名称,那么这些(往往同是全局级的)命名空间本身,也可能发生名称冲突。

如果为了避免冲突,而为命名空间取很长的名称,则使用起来就会不方便。

这是一个典型的两难问题。

标准C++为此提供了一种解决方案——命名空间别名,格式为:

namespace别名=命名空间名;

(AT&

T美国电话电报公司)

namespaceAmerican_Telephone_and_Telegraph{//命名空间名太长

classString{

String(constchar*);

//……

American_Telephone_and_Telegraph:

Strings1//使用不方便

=newAmerican_Telephone_and_Telegraph:

String("

Grieg"

namespaceATT=American_Telephone_and_Telegraph;

//定义别名

ATT:

Strings2=newATT:

Bush"

//使用方便

Strings3=newATT:

Nielsen"

无名命名空间

标准C++引入命名空间,除了可以避免成员的名称发生冲突之外,还可以使代码保持局部性,从而保护代码不被他人非法使用。

如果你的目的主要是后者,而且又为替命名空间取一个好听、有意义、且与别人的命名空间不重名的名称而烦恼的话,标准C++还允许你定义一个无名命名空间。

你可以在当前编译单元中(无名命名空间之外),直接使用无名命名空间中的成员名称,但是在当前编译单元之外,它又是不可见的。

无名命名空间的定义格式为:

namespace{

声明序列可选

实际上,上面的定义等价于:

(标准C++中有一个隐含的使用指令)

namespace$$${

usingnamespace$$$;

voidf(){/*……*/}

intmain(){

//可直接使用无名命名空间中的成员i

//可直接使用无名命名空间中的成员f()

引用自touzani的专栏.C++命名空间namespace

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 企业管理

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1