首先今天想敲代码然后第一行“#include<iostream.h>”就出现错误,搞了一会又该这个又改那个,最后发现把 ".h"去掉就可以了。
然后上网查了为什么会这样,iosream和iostream.h有什么不同。
最后还引出了iostream的命名空间问题:using namespace std
以下是我找到的答案
C++标准程序库中的所有标识符都被定义于一个名为std的namespace中。 由于namespace的概念,使用C++标准程序库的任何标识符时,可以有三种选择:
直接指定标识符
例如std::iostream而不是iostream。完整语句如下:
std::cout<<std::hex<<3.4<<std::endl;
使用using关键字
使用using关键字
加入using std::cout; using std::endl; using std::cin; 则前面语句可以写成如下代码:
cout << 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>和<iostream.h>等等这样的头文件,一个是为了兼容以前的C++代码,一个是为了支持新的标准。
iostream和iostream.h,前者没有后缀。实际上,在你的编译器include文件夹里面可以看到,二者是两个文件。打开文件就会发现,
里面的代码是不一样的。 后缀为.h的头文件c++标准已经明确提出不支持了,早些的实现将标准库功能定义在全局空间里,
声明在带.h后缀的头文件里,c++标准为了和C区别开,也为了正确使用命名空间,规定头文件不使用后缀.h。
因 此,当使用<iostream.h>时,相当于在c中调用库函数,使用的是全局命名空间,也就是早期的c++实现;
当使用< iostream>的时候,该头文件没有定义全局命名空间,必须使用namespace std;这样才能正确使用cout。
命名空间std封装的是标准程序库的名称,