C++学习之旅get、getline的用法
面向行的输入:cin.getline()。
该函数读取整行,它使用通过回车键输入的换行符来确定输入结尾。要调用这种方法,可以使用cin.getline().该函数有两个参数。第一个参数是用来存储输入行的数组名称,第二个参数是要读取的字符数。如果这个参数为20,则该函数最多读取19个字符,余下的空间用于存储自动在结尾处添加的空字符’\0’.getline()成员函数在读取指定数目的字符或遇到换行符时停止读取。
面向行的输入:cin.get()。istream类有另一个名为get()的成员函数,该函数有几种变体,其中一种变体的工 作方式与getline()类似,它们接收的参数相同,解释的参数也相同,并且每次都读取到行尾。但是get并不再读取并丢弃换行符,而是将其留在输入队列中。假设我们连续两次调用get();
cin.get(name, ArSize);
cin.get(dessert, ArSize);
由于第一次调用后,换行符将留在输入队列中,因此第二次调用时看到第一个字符便是换行符。因此get()认为已经到达行尾,而没有发现任何可读取的内容。如果不借助与帮助,get将不能跳过换行符。幸运的是get()有另外一种变体,cin.get()它可以吃掉换行符。
比如:
cin.get(name, ArSize);
cin.get();
cin.get(dessert, ArSize);
另一种用法是将两个成员函数拼接起来(合并)
cin.get(name, ArSize).get()
之所以这样做的原因是由于cin.get(name, ArSirze)返回一个cin对象,该对象随后被用来调用get()
需要注意的是:有些C++的老版本没有实现不接受任何参数的get()变体,但是实现了接受一个char参数的get()变体,要使用该变体需要首先声明一个char变量。
char ch;
cin.get(name, ArSize).get(ch);
空行以及其他问题:
当getline()或get()读取空行时,将会发生什么情况呢?
最初的做法:下一条语句将在前一条getline()或get()结束读取的位置开始读取。
但是当前的做法是,当get()读取到空行后将设置失效位(falibit)。这意味着接下来的输入将被阻断。
但可以用下面的命令来恢复输入:
cin.clear();
另一个潜在的问题是,输入字符串可能比分配的空间长。如果输入行包含的字符比指定的字符多,则getline()和get()将把余下的字符留给输入队列,而getline()还会设置失效位,并关闭其后面的输入。
需要指出的一点是:C++允许函数有多个版本,条件是这些版本的参数列表不同。如果使用的是cin.get(name, ArSize),则编译器知道要将一个字符串放入到数组中,因而将使用适当的成员函数。如果使用的是cin.get(),则编译器知道要读取一个字符———这是一种函数重载
为什么要使用get(),而不是getline()呢?因为老式实现是没有getline()的,其次get()使的输入更加的仔细、例如,假设用get()将一行读入数组中。如何知道停止读取的原因是由于读取了整行(换行符)还是由于数组已经填满了呢?查看下一个输入字符,如果是换行符则说明已经读取了整行,否则说明该行中还有其他输入。总之,getline()使用起来简单一些,但是get()使得检查错误更简单一些。可以用其中的任何一个来读取一行输入。但是我们要知道他们的行为是有些不同的。