zoukankan      html  css  js  c++  java
  • #include<iostream>与#include<iostream.h>的区别

    这两者都有什么不同呢?首先,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 > ^_^
  • 相关阅读:
    链表首尾节点的常规方案
    MYSQL 学习
    卡尔曼滤波
    降维技术
    Hurst指数python实现
    一维GMM的Python代码实现
    对数周期幂率模型(LPPL)
    paper 112:hellinger distance
    paper 111:图像分类物体目标检测 from RCNN to YOLO
    paper 110:凸优化和非凸优化
  • 原文地址:https://www.cnblogs.com/renyuan/p/3099817.html
Copyright © 2011-2022 走看看