#include<iostream>与#include<iostream.h>的区别

本文详细介绍了C++中&lt;iostream&gt;与&lt;iostream.h&gt;的区别,包括命名空间的影响、模板化I/O类的支持以及与C兼容性的处理方式。同时,对比了&lt;string.h&gt;、&lt;string&gt;和&lt;cstring&gt;在字符串处理方面的不同。
摘要由CSDN通过智能技术生成

原文转自:http://blog.sina.com.cn/s/blog_514b5f600100ayks.html


        这两者都有什么不同呢?首先,5年前我们就开始反对把.h符号继续用在标准的头文件中。继续使用过时的规则可不是个好的方法。从功能性的角度来讲,<iostream>包含了一系列模板化的I/O类,相反地<iostream.h>只仅仅是支持字符流。另外,输入输出流的C++标准规范接口在一些微妙的细节上都已改进,因此,<iostream>和<iostream.h>在接口和执行上都是不同的。最后,<iostream>的各组成都是以STL(Standard Template Library,标准模板库)的形式声明的,然而<iostream.h>的各组成都是声明成全局型的。



        因为这些实质上的不同,你不能在一个程序中混淆使用这两个库。做为一种习惯,在新的代码中一般使用<iostream>,但如果你处理的是过去编写的代码,为了继承可以用继续用<iostream.h>就保持代码的一致性。
/
<iostream>表示你使用的是标注命名空间,也就是在程序开始应该有这么一句话
using namespace std ; 这是遵循c++标准的
<iostream.h> 则没有遵循c++标准
/
<string.h>是旧的C头文件,对应的是基于char*的字符串处理函数;
<string>是包装了std的C++头文件,对应的是新的strng类;
<cstring>是对应旧的C头文件的std版本。
#include <iostream.h> 和 #include <iostream>   
前一个不是c++标准中的,后一个在c++标准中
还有就是平时我们所用的两种情况,当有输出和输入流时就要注意了。
换成#include <iostream>,要加一句using namespace std;或把cout改成std::cout,end改成std::endl等等
///
这个问题牵扯到命名空间,以下简单介绍命名空间的优点:
// one.h char func(char); class String { ... };
// somelib.h class String { ... };
如果按照上述方式定义,那么这两个头文件不可能包含在同一个程序中,因为String类会发生冲突。所谓命名空间,是一种将程序库名称封装起来的方法,它就像在各个程序库中立起一道道围墙。比如: // one.h namespace one { char func(char); class String { ... }; }
// somelib.h namespace SomeLib { class String { ... }; }
std是C++标准库定义的标准命名空间,可以先记住这两种方式,时间长了就明白了
/
对于这个问题,某个马嘉楠老师如是说:
其实没有< iostream.h > 这样的东西 --- 标准化委员会在简化非C标准头文件时用< iostream > 取代了它。但又没有完全取消 < iostream.h > 的使用,并且很多编译器都同时支持< iostream > 和< iostream.h > ,造成现在的局面,老大(标准化委员会)确实有不得已的苦衷。
 
        话说当年,在标准化委员会动手重建新的标准库的时候,遇到了问题。为了避免类名和函数名的冲突问题,引入了名字空间std。但无数现有的C++代码都依赖于使用了多年的伪标准库中的功能,例如,声明在< iostream.h > 和< complex.h > 等头文件中的功能。现有软件没有针对使用名字空间而进行相应的设计或升级,如果用std来包装标准库导致现有代码不能使用,那手底下的小弟(程序员)是不会同意的。
        标准化委员会为了拉拢人心,吸引更多的人入会,决定为包装了std的那部分标准库构建新的头文件名。将现有C++头文件名中的.h去掉,所以就出现了< iostream.h> 和< iostream > 等很多双胞胎。对于C头文件,采用同样方法但在每个名字前还要添加一个C,所以C的<string.h> 变成了<cstring>。
      旧的C++头文件是官方明确反对使用的,但旧的C头文件则没有(以保持对C的兼容性)。其实编译器制造商不会停止对客户现有软件提供支持,所以在可以预计的将来,旧的C++头文件还会嚣张一段时间。如果能明白字符串头文件的使用,举一反三,其他的也差不多会用了。
<string.h> 是旧的C头文件,对应的是基于char*的字符串处理函数;
<string> 是包装了std的C++头文件,对应的是新的strng类;
<cstring> 是对应旧的C头文件的std版本。
        跑远了,言归正传。如果你的编译器都同时支持< iostream > 和< iostream.h >,那使用 #include < iostream >,得到的是置于名字空间std下的iostream库的元素;如果使用 #include < iostream.h >,得到的是置于全局空间的同样的元素。在全局空间获取元素会导致名字冲突,而设计名字空间的初衷正是用来避免这种名字冲突的发生。还有,打字时< iostream > 比 < iostream.h > 少两个字,所以我会使用< iostream > ^_^
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值