<iosteam.h>和<stdio.h>的区别?

如题所述

c里用stdio.h,c++里用iostream

尽量用<iostream>而不用<stdio.h>
是的,scanf和printf很轻巧,很高效,你也早就知道怎么用它们,这我承认。但尽管他们很有用,事实上scanf和printf及其系列还可以做些改进。尤其是,他们不是类型安全的,而且没有扩展性。因为类型安全和扩展性是C++的基石,所以你也要服从这一点。另外,scanf/printf系列函数把要读写的变量和控制读写格式的信息分开来,就象古老的FORTRAN那样。是该向五十年代说诀别的时候了!
不必惊奇,scanf/printf的这些弱点正是操作符>>和<<的强项:
int i;
Rational r;// r 是个有理数
...
cin >> i >> r;
cout << i << r;
上面的代码要通过编译,>>和<<必须是可以处理Rational类型对象的重载函数(可能要通过隐式类型转换)。如果没有实现这样的函数,就会出错(处理int不用这样做,因为它是标准用法)。另外,编译器自己可以根据不同的变量类型选择操作符的不同形式,所以不必劳你去指定第一个要读写的对象是int而第二个是Rational。
另外,在传递读和写的对象时采用的语法形式相同,所以不必象scanf那样死记一些规定,比如如果没有得到指针,必须加上地址符,而如果已经得到了指针,又要确定不要加上地址符。这些完全可以交给C++编译器去做。编译器没别的什么事好做的,而你却不一样。最后要注意的是,象int这样的固定类型和象Rational这样的自定义类型在读写时方式是一样的。而你用sacnf和printf试试看!
你所写的表示有理数的类的代码可能象下面这样:
class Rational {
public:
Rational(int numerator = 0, int denominator = 1);
...
private:
int n, d;// 分子,分母
friend ostream& operator<<(ostream& s, const Rational& );
};
ostream& operator<<(ostream& s, const Rational& r)
{
s<< r.n << '/' << r.d;
return s;
}
上面的代码涉及到operator<<的一些微妙(但很重要)的用法,这在本书其他地方详细讨论。例如:上面的operator<<不是成员函数(条款19解释了为什么),而且,传递给operator<<的不是Rational对象,而是定义为const的对象的引用(参见条款22)。operator>>的声明和实现也类似。
尽管我不大愿意承认,可有些情况下回到那些经过证明而且正确的老路上去还是很有意义的。第一,有些iostream的操作实现起来比相应的C stream效率要低,所以不同的选择会给你的程序有可能(虽然不一定,参见条款M16)带来很大的不同。但请牢记,这不是对所有的iostream而言,只是一些特殊的实现;参见条款M23。第二,在标准化的过程中,iostream库在底层做了很多修改(参见条款49),所以对那些要求最大可移植性的应用程序来说,会发现不同的厂商遵循标准的程度也不同。第三,iostream库的类有构造函数而<stdio.h>里的函数没有,在某些涉及到静态对象初始化顺序的时候,如果可以确认不会带来隐患,用标准C库会更简单实用。
iostream库的类和函数所提供的类型安全和可扩展性的价值远远超过你当初的想象,所以不要仅仅因为你用惯了<stdio.h>而舍弃它。毕竟,转换到iostream后,你也不会忘掉<stdio.h>。
顺便说一句,本条款的标题没有打印错;我确实说的是<iostream>而非<iostream.h>。从技术上说,其实没有<iostream.h>这样的东西——标准化委员会在简化非C标准头文件时用<iostream>取代了它。他们这样做的原因在条款49进行了解释。还必须知道的是,如果编译器同时支持 <iostream>和<iostream.h>,那头文件名的使用会很微妙。例如,如果使用了#include <iostream>, 得到的是置于名字空间std(见条款28)下的iostream库的元素;如果使用#include <iostream.h>,得到的是置于全局空间的同样的元素。在全局空间获取元素会导致名字冲突,而设计名字空间的初衷正是用来避免这种名字冲突的发生。还有,打字时<iostream>比<iostream.h>少两个字,这也是很多人用它的原因。:)
温馨提示:内容为网友见解,仅供参考
无其他回答

<iosteam.h>和<stdio.h>的区别?
第三,iostream库的类有构造函数而<stdio.h>里的函数没有,在某些涉及到静态对象初始化顺序的时候,如果可以确认不会带来隐患,用标准C库会更简单实用。iostream库的类和函数所提供的类型安全和可扩展性的价值远远超过你当初的想象,所以不要仅仅因为你用惯了<stdio.h>而舍弃它。毕竟,转换到iostream后...

#include <iosteam>
你缺少头文件,你装的是什么编译程序,你需要指定头文件,如果你创建的是win32控制台程序,你需要将头文件包含进去,如果你只有cpp文件的话,你也许可以把iostream。h文件打开,在你的安装文件夹内搜索就可以了,我没试过,自己想想办法吧

c++的头文件什么时候用哪个呢
IO.H 包含低级I\/O子程序的结构和说明。LIMIT.H 包含各环境参数、编译时间限制、数的范围等信息。MATH.H 说明数学运算函数,还定了 HUGE VAL 宏, 说明了matherr和matherr子程序用到的特殊结构。MEM.H 说明一些内存操作函数(其中大多数也在STRING.H 中说明)。 PROCESS.H 说明进程管理的各个函数,...

c++的头文件什么时候用哪个呢
现在来看看下面两个include: #include<iostream> \/\/ 这个就是1998年标准化以后的标准头文件 #include<iostream.h> \/\/ 这个就是标准化以前的头文件 更本质上的区别就是iostream把标准C++库的组件放在一个名位std的namespace里面。而相对的iostream.h则将这些标准组件放在全局空间里,同...

c++中源程序中如果是#include<iostream.h>,还需要用using namespace st...
无数原有的C++代码都依赖于使用了多年的伪标准库中的功能,他们都是在全局空间下的。 所以就有了<iostream>和<iostream.h>等等这样的头文件,一个是为了兼容以前的C++代码,一个是为了支持新的标准。 命名空间std封装的是标准程序库的名称,标准程序库为了和以前的头文件区别,一般不加".h"...

从键盘输入一段英文,统计并输出单词个数
\/\/有一篇文章,共有3行文字,每行有80个字符。要求分别统计出其中英文大写字母、小写字母、数字、空格以及其他字符的个数。include <iostream.h> include <stdio.h> void main(){ char ch[3][80];cout<<"请输入短文,每行80个字符,回车结束:"<<endl;for(int i=0;i<3;i++)gets(ch[i]...

C++;将一元人民币兑换成1,2,5分的硬币,有多少种换法
include<stdio.h> void main(){ int a,b,c,d=0;for(a=0;a<=100;a++)for(b=0;b<=50;b++)for(c=0;c<=20;c++){ if(100==(a+2*b+5*c)){ printf("%d,%d,%d\\n",a,b,c);d=d+1;} } printf("%s%d%s\\n","总共有",d,"种换法。");} 主要是增加了变量 d 来...

java将数据导出excel计算其文件大小
Linux下读写文件操作 #include<stdio.h> typedef struct Student { int no; char name[10]; int score; }Student; int main(int args,char *argv[]) { \/\/打开文件 FILE *fp=fopen("test.txt","w"); if(fp=NULL) { perror("fopen"); ...继续访问Java导出超大Excel文件,防止内存溢出Java导出超大...

附加: FFmpeg概念理解
#include<stdio.h>#include<string.h>intmain(){charcommand[50];strcpy(command,"ffmpeg –s w*h –pix_fmt yuv420p –i input.yuv –vcodec mpeg4 output.avi");system(command);return(0);} FFMpeg 中比较重要的函数以及数据结构如下: 数据结构: (1) AVFormatContext (2) AVOutputFormat (3) AVInputF...

有一分数序列1\/2,3\/4,5\/6,7\/8...19\/20,怎样求该序列的和,请写出程序...
include <iosteam.h> void main(){ int,i,sum;sum=0;for(i=1;i<20;i++)sum+=i\/(i+1);cout<<sum;}

相似回答