按行输入的实现方法

来源:互联网 发布:sql中replace判断空值 编辑:程序博客网 时间:2024/05/22 15:34

有三种方法实现按行输入:

<1>成员函数get()。

<2>成员函数getline()。

<3>定义在头文件<string>中的全局函数getline()。


前两个函数有三个参数:

<1>.指向字符缓冲区的指针,用于保存结果。

<2>.缓冲区的大小(为了保证缓冲区不会溢出)。

<3>.结束字符,根据结束字符判断停止读入操作,默认为'\n',在输入过程中遇到结束字符时,这两个函数都会在结果缓冲区莫为存储一个零。


前两个函数细微而重要的区别:

当遇到输入流中的结束字符时,get()停止执行,但不从输入流中提取结束字符。

而getline()刚好相反,将从输入流中提取结束字符,但仍不会把它存储到结果缓冲区。


第三个<string>中的全局函数getline():

不是成员函数,而是在名字空间std中声明的独立函数,仅有两个非默认参数:<1>. 输入流<2>. string对象。

它从输入流中读取字符直到遇到结束字符(默认为‘\n’),并丢弃这个界定符。函数的优点是它把数据读入到一个string对象中,不需担心缓冲区的大小。

一般,当采用按行输入的方式处理文本文件时,需要使用以上其中一个getline()函数。


另外,get()函数的三个重载版本:

<1>.无参数,使用int作为返回值类型,返回下一个字符。

<2>.使用char类型的引用作为参数,函数从流中读取一个字符放到这个参数中。

<3>.把流对象直接存储到基础的缓冲区结构。

原创粉丝点击