能够啊、、只是命名空间的声明而已。意思就是说下面的函数,若是有和stl库里面一个名字的,就是用的stl的函数
C++ using namespace std 详解
所谓namespace,是指标识符的各类可见范围。C++标准程序库中的全部标识符都被定义于一个名为std的namespace中。
一 :
<iostream>和<iostream.h>是不同,前者没有后缀,实际上,在你的编译器include文件夹里面能够看到,两者是两个文件,打开文件就会发现,里面的代码是不同的。
后缀为.h的头文件c++标准已经明确提出不支持了,早些的实现将标准库功能定义在全局空间里,声明在带.h后缀的头文件里,c++标准为了和C区别开,也为了正确使用命名空间,规定头文件不使用后缀.h。
所以,当使用<iostream.h>时,至关于在c中调用库函数,使用的是全局命名空间,也就是早期的c++实现;当使用<iostream>的时候,该头文件没有定义全局命名空间,必须使用namespacestd;这样才能正确使用cout。
二:
所谓namespace,是指标识符的各类可见范围。
C++标准程序库中的全部标识符都被定义于一个名为std的namespace中。
因为namespace的概念,使用C++标准程序库的任何标识符时,能够有三种选择:
一、直接指定标识符。例如std::ostream而不是ostream。完整语句以下:
std::cout << std::hex<< 3.4<< std::endl;
二、使用using关键字。
using std::cout;
using std::endl;
以上程序能够写成
cout << std::hex<< 3.4<< endl;
三、最方便的就是使用using namespace std;
例如:
#include <iostream>
#include <sstream>
#include <string>
using namespace std;
这样命名空间std内定义的全部标识符都有效(曝光)。就好像它们被声明为全局变量同样。那么以上语句能够以下写:
cout << hex<< 3.4<< endl;
由于标准库很是的庞大,所程序员在选择的类的名称或函数名时就颇有可能和标准库中的某个名字相同。因此为了不这种状况所形成的名字冲突,就把标准库中的一切都被放在名字空间std中。但这又会带来了一个新问题。无数原有的C++代码都依赖于使用了多年的伪标准库中的功能,他们都是在全局空间下的。
因此就有了<iostream.h>和<iostream>等等这样的头文件,一个是为了兼容之前的C++代码,一个是为了支持新的标准。
命名空间std封装的是标准程序库的名称,标准程序库为了和之前的头文件区别,通常不加".h"ios