博客
关于我
C++:while(getline())函数
阅读量:486 次
发布时间:2019-03-06

本文共 3817 字,大约阅读时间需要 12 分钟。

首先说明getline()的原型:getline(istream &is,string &str,char delim)

istream &is表示一个输入流,譬如cin,string表示把从输入流读入的字符串存放在这个字符串中(&str其实就是一个变量),char delim是终止符(默认为回车,还可以是别的符号,如#,*之类的都可以)

对于while(getline(cin,str))来讲,while语句的真实判断对象是cin,也就是当前是否存在有效的输入流,如果存在就不会结束循环。

尽量使用全局函数string类中的getline(),其读入的第二个参数为string类型,不设置默认是遇到回车停止读入操作

cin.getline是针对数组字符串的,以指定的地址为存放第一个读取的字符的位置,依次向后存放读取的字符,直到读满N-1个,或者遇到指定的结束符为止

全局函数的getline(cin,str);处理后还留有结束符在输入流中,故需要使用cin.get();//接受最后一个结束符,才能接受后面得输入值。

------总结:getline()函数

一、string类的getline函数(全局函数)

getline(cin,str)函数是处理string类的函数。第二个参数为string类型的变量。读入时第二个参数为string类型,而不是char*,要注意区别

        getline()函数的定义如下所示

        1. istream& getline ( istream &is , string &str , char delim );

        2. istream& getline ( istream &is , string &str );

is 进行读入操作的输入流

str 用来存储读入的内容

delim 终结符,遇到该字符停止读取操作,不写的话默认为回车,

函数的返回值:

        与参数is一样。(------------------while进行下一次循环时,怎么知道.txt文本中第一行已经进行输出完要从第二行开始输出的?----------------解答:

getline 这个函数的作用就是读取一行,它会自动区分每一行文本的

每一行文本之间都有换行符,他根据换行符来区分

就是第一行读完之后,自动跳到第二行开头

来看一个包含多个名称和地址的文件,其内部格式如下:

可以将该文件看成是由 3 个记录组成的。记录是关于单个项目的完整信息集。另外,文件中的记录由 3 个字段组成:

  • 第一个字段就是某人的名字;
  • 第二个字段是某人的街道地址或邮政信箱号码;
  • 第三个字段包含某人的城市、州和邮政编码。

请注意,每个字段以 $ 字符结尾,每个记录以 \n 字符结尾。下面的程序演示了如何使用 getline 函数来检测 $ 字符:

// This file demonstrates the getline function with a user-specified delimiter.#include 
#include
#include
using namespace std;int main(){ // Variable needed to read file string input; // Open the file. fstream dataFile ("addresses.txt", ios::in); if (!dataFile) { cout << "Error opening file."; return 0; } // Read lines terminated by '$'' sign and output getline(dataFile, input, '$'); while (!dataFile.fail()) //while(dataFile) //这两种while判断语句都可以 { cout << input << endl; getline(dataFile, input, '$'); //??????????怎么检测到第一行已经输出,要从第二行开始输出??????????? } // Close the file dataFile.close (); return 0;}

程序输出结果:

 

 

        前方预警,请各位看官注意!!!

        所以在使用while(getline(cin,line))的时候,判断while()是否结束循环的条件不是输入流是否输入了回车(或getline函数里你自己定义的结束符),而是getline这个函数是否输入无效(这么说好像有点绕,给你们来个爽快的)。直到你输入了EOF或者ctrl+z,while循环才会结束,(

即读取到文件末尾的时候就不能再读取了,这个时候就会读取失败,这样循环就结束了。就是到了末尾了,再往后没东西就表示到了末尾了

在C++里面,到了末尾,就用EOF表示

但是文件的末尾本来就是没有什么特殊标志的)

而且要注意的是,只有getline函数动作完毕时,while才会执行内部的循环,例如 :

while(getline(cin,str))        {                       cout<
<

直到你输入了回车或者你自己设定的结束符,str这个字符串才会被输出。

让我们一起来分析一下while(getline(cin,line))语句

注意这里默认回车符停止读入,按Ctrl+Z或键入EOF回车即可退出循环。

在这个语句中,首先getline从标准输入设备上读入字符,然后返回给输入流cin,注意了,是cin,所以while判断语句的真实判断对象是cin,也就是判断当前是否存在有效的输入流。在这种情况下,我想只要你的电脑不中毒不发神经你的输入流怎么会没有效?所以这种情况下不管你怎么输入都跳不出循环,因为你的输入流有效,跳不出循环。

然而有些同学误以为while判断语句的判断对象是line(也就是line是否为空),然后想通过直接回车(即输入一个空的line)跳出循环,却发现怎么也跳不出循环。这是因为你的回车只会终止getline()函数的读入操作。getline()函数终止后又进行while()判断(即判断输入流是否有效,你的输入流当然有效,满足条件),所以又运行getline()函数,导致程序永远跳不出循环。

        注意:上面讲到的getline(cin,str)实际是一个全局函数,本身属于string类。所以你使用该函数的时候请记得添加#include <string>头文件。下面介绍一个与getline很相似的函数cin.getline。

cin.getline()函数是处理数组字符串的,其原型为cin.getline(char * , int),第一个参数为一个char指针,第二个参数为数组字符串长度。

cin.getline()当输入超长时,会引起cin函数的错误,后面的cin操作将不再执行。如下代码:

void test_input(){char ch1,ch2[10];cout<<"请输入字符串:"<
>ch1;cout<
<
<
<<"\n"<<(int)ch1<

测试:如下图,输入zifuchuan[Enter],长度大于最大长度5,就会导致cin函数错误,其后既没有像cin.get()一样直接从输入缓冲区直接读数据,也没有从键盘输入。所以此处可以注意,考虑在用cin.getline()时,适度设置其最大接受长度大一点。

cin.getline()

此函数会一次读取多个字符(包括空白字符)。它以指定的地址为存放第一个读取的字符的位置,依次向后存放读取的字符,直到读满N-1个,或者遇到指定的结束符为止。若不指定结束符,则默认结束符为'\n'。其语法为:

cin.getline(字符指针(char*),字符个数N(int),结束符(char));
#include "stdafx.h"#include
#include
#include
using namespace std; int main(){char a[30];cout << "请输入一个字符串:" << endl;cin.getline(a, 10);//第10位存放字符串结束符'\0'for (int i = 0; i<10; i++)cout << "第"<
<<"个值为:"<
<< endl; return 0;}

输入:1234567890123

输出:1 2 3 4 5 6 7 8 9 _ (第10位存放字符串结束符'\0')

参照博客:

转载地址:http://wemdz.baihongyu.com/

你可能感兴趣的文章
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>
mysql 的存储引擎介绍
查看>>
MySQL 的存储引擎有哪些?为什么常用InnoDB?
查看>>