<iostream> 和 <iostream.h>的区别 及 Linux下编译iostream.h的方法

0、序言

其实2者主要的区别就是iostream是C++标准的输入输出流头文件,而iostream.h是非标准的头文件。

标准头文件iostream中的函数属于标准命令空间,而iostream.h中的函数都是全局函数。

#include <iostream>     //这个就是C++98标准化以后的标准头文件
#include <iostream.h>   //这个就是标准化以前的头文件(当时还没有命令空间的概念

 

1、两者使用时的区别

以函数cout和endl举例说明。

1.1 iostream.h 的使用

由于iostream.h中函数都是全局的,使用的方法同C相同。

//example.cpp
#include <iostream.h> int main(void) {   cout<<"Hello World"<<endl;   return 0; }

  1.1.1 iostream.h 的编译

在Windows平台下的VC++/VS中编译没什么好说的,直接可以编译通过.

在Linux下编译需要详细的说明一下。

上面的例子examplec.pp使用下面普通的方法编译,甚至提示找不到iostream.h这个头文件

# g++ example.cpp
error: iostream.h: No such file or directory
error: ‘cout’ was not declared in this scope
error: ‘endl’ was not declared in this scope

 没有头文件怎么办呢?这需要安装兼容包,在我的64位系统安装了下面2个包(还有其他包)

# yum install compat-gcc*

Install compat-gcc-34.x86_64
Install compat-gcc-34-c++.x86_64

 记住上面包的名字中的数字34,在不同系统中可能是不同的,继续编译,注意这次使用的不是g++而是g++34.

# g++34example.cpp
 In file included from /usr/lib/gcc/x86_64-redhat-linux/3.4.6/../../../../include/c++/3.4.6/backward/iostream.h:31, from main.cpp:8: /usr/lib/gcc/x86_64-redhat-linux/3.4.6/../../../../include/c++/3.4.6/backward/backward_warning.h:32:2: warning: #warning This file includes at least one deprecated or antiquated header. Please consider using one of the 32 headers found in section 17.4.1.2 of the C++ standard. Examples include substituting the <X> header for the <X.h> header for C++ includes, or <iostream> instead of the deprecated header <iostream.h>. To disable this warning use -Wno-deprecated.

 这次编译有一个很长的warning,意思就是建议使用标准头文件不使用非标准头文件。

非要使用非标准头文件的时候可以通过添加编译选项-Wno-deprecated 来取消这个warning

# g++34 -g example.cpp -Wno-deprecated

 OK,到此就编译成功了。

 

1.2 iostream 的使用

主要有3种方法,没有最优,只有最合适

 方法1,适用于使用函数个数少,函数使用次数少 的情况

//example1.cpp
#include <iostream>

int main(void)
{
  std::cout<<"Hello World"<<std::endl; //方法1
  return 0;
}

 方法2,适用于使用函数个数少,函数使用次数较多 的情况

//example2.cpp
#include <iostream>
using std::cout;              //方法2
using std::endl;              //方法2

int main(void)
{
  cout<<"Hello World"<<endl;
  return 0;
}

 方法3,适用于使用函数个数和函数次数较多 的情况

//example3.cpp
#include <iostream>
using namespace std;            //方法3

int main(void)
{
  cout<<"Hello World"<<endl;
  return 0;
}

 

2、建议

最好使用标准头文件.

iostream是现在C++中规定的标准,目的在于使C++代码用于移植和混合嵌入时不受扩展名.h的限制,避免因为.h而造成的额外的处理和修改。

iostream包含的基本功能和对应的旧头文件相同,但头文件的内容在名字空间std中。

(在标准化的过程中,库中有些部分的细节被修改了,所以旧头文件和新头文件中的实体不一定完全对应。)

一般情况下应该用这个头文件,而iostream.h则是老式的,以后有可能被淘汰。

 

3、历史

在回过头来看看标准程序库,这个程序库涵盖范围相当广大,提过了许许多多好用的功能。

正是因为这样标准程序库中class的名称和函数名与第三方提供的程序库中的class名或是函数名发生名字冲突的可能性大大增大。

为了避免这个问题的发生,标准委员会决定将标准程序库中每一样东西都放在namespace std中。

但是这么做同时有引来了一个新的问题。很多C++程序代码依赖那些已经存在很多年的C++ “准”标准程序库(C++迟迟未标准化才导致这些情况的发生),例如iosteam.h,complex.h等等。

 为了解决这个新出现的问题,标准化委员会决定设计一些新的头文件名,给那些穿上std外衣的组件所使用。

把C++头文件的.h去掉,于是就有前面出现的iostream,同样C的头文件也做了相同的处理,同时在前面加上了一个字母c,以表示是C的头文件(感觉上有中种族歧视的感觉)。

同时标准化委员会声明就有的C++头文件将不再列于被支持的名单之中了,而旧有的C头文件为了满足“对C的兼容性”这个古老契约,仍然将继续存活下去。

 但是,那些编译器厂商不可能去推翻他们客户的旧有编译器(也跟本不会去这么做),所以那些旧有的C++头文件仍然苟延残喘的活了下来,并不断的扰乱那些C++新兵的心智。

 

下面就是现在大多数C++开发工具表示头文件的组织状态:

1.旧的C++头文件 比如iostream.h,他们虽然被标准化委员会所抛弃,但由于各大厂商为了各自的商业利益仍然将继续存活下去,这些头文件的内容将不处于namespace std中。

2.新的C++头文件如iostream虽然提供了和旧有头文件相同的功能,但他的内容都并入了namespace std中,从而有效避免了名字污染的问题。

3.标准C的头文件如stdio.h继续获得支持,这类文件的内容并未放在std中。

4.C函数库的技能也有对应的新式C++版本,起名称类似cstdio,这类头文件的内容也有幸穿上了std的外衣。

 

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------

参考资料:

http://hi.baidu.com/laddie10/blog/item/079b1d4c32d7d8fcd62afc25.html

http://bbs.sjtu.edu.cn/bbstcon,board,C,reid,1101133248,file,M.1101178603.A.html

 

 

 

 

 

 

 

posted @ 2014-05-06 10:47  LubinLew  阅读(8154)  评论(0编辑  收藏  举报