<iostream> 和 <iostream.h>的区别 及 Linux下编译iostream.h的方法_VMware, Unix及操作系统讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  VMware, Unix及操作系统讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1998 | 回复: 0   主题: <iostream> 和 <iostream.h>的区别 及 Linux下编译iostream.h的方法        下一篇 
xiaojiang
注册用户
等级:少尉
经验:345
发帖:77
精华:0
注册:2011-8-31
状态:离线
发送短消息息给xiaojiang 加好友    发送短消息息给xiaojiang 发消息
发表于: IP:您无权察看 2015-6-24 9:24:52 | [全部帖] [楼主帖] 楼主

其实两者主要的区别就是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>
usingnamespace 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的外衣。

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论