C++的get()函数与getline()函数使用详解

C++ get()函数读入一个字符
get()函数是cin输入流对象的成员函数,它有3种形式:无参数的,有一个参数的,有3个参数的。
1) 不带参数的get函数
其调用形式为

  cin.get()

用来从指定的输入流中提取一个字符(包括空白字符),函数的返回值就是读入的字符。 若遇到输入流中的文件结束符,则函数值返回文件结束标志EOF(End Of File),一般以-1代表EOF,用-1而不用0或正值,是考虑到不与字符的ASCII代码混淆,但不同的C ++系统所用的EOF值有可能不同。

[例] 用get函数读入字符。

#include <iostream>
using namespace std;
int main( )
{
int c;
cout<<"enter a sentence:"<<endl;
while((c=cin.get())!=EOF)
cout.put(c);
return 0;
}

运行情况如下:

enter a sentence:
I study C++ very hard.(输入一行字符)
I study C++ very hard.       (输出该行字符)
^Z(程序结束)

C语言中的getchar函数与流成员函数cin.get( )的功能相同,C++保留了C的这种用法,可以用getchar(c)从键盘读入一个字符赋给c。

2) 有一个参数的get函数
其调用形式为

 cin.get(ch)

其作用是从输入流中读取一个字符,赋给字符变量ch。如果读取成功则函数返回true(真),如失败(遇文件结束符) 则函数返回false(假)。上面的例子可以改写如下:

#include <iostream>
using namespace std;
int main( )
{
  char c;
  cout<<"enter a sentence:"<<endl;
  while(cin.get(c)) //读取一个字符赋给字符变量c,如果读取成功,cin.get(c)为真
  {cout.put(c);}
  cout<<"end"<<endl;
  return 0;
}

3) 有3个参数的get函数
其调用形式为
    cin.get(字符数组, 字符个数n, 终止字符)

    cin.get(字符指针, 字符个数n, 终止字符)
其作用是从输入流中读取n-1个字符,赋给指定的字符数组(或字符指针指向的数组),如果在读取n-1个字符之前遇到指定的终止字符,则提前结束读取。如果读取成功则函数返回true(真),如失败(遇文件结束符) 则函数返回false(假)。再将例13.6改写如下:

#include <iostream>
using namespace std;
int main( )
{
  char ch[20];
  cout<<"enter a sentence:"<<endl;
  cin.get(ch,10,'\\n');//指定换行符为终止字符
 cout<<ch<<endl;
  return 0;
}

运行情况如下:

enter a sentence:
I study C++ very hard.
I study

在输入流中有22个字符,但由于在get函数中指定的n为10,读取n -1个(即9个)字符并赋给字符数组ch中前9个元素。有人可能要问:指定n-10,为什么只读取9个字符呢?因为存放的是一个字符串,因此在9个字符之后要加入一个字符串结束标志,实际上存放到数组中的是10个字符。请读者思考:如果不加入字符串结束标志,会 出现什么情况?结果是:在用“cout<<ch”;输出数组中的字符时,不是输出读入的字符串,而是数组中的全部元素。大家可以亲自测试一下ch[9](即数组中第10个元素)的值是什么。

如果输入

  abcde

即未读完第9个字符就遇到终止字符、读取操作终止,前5个字符已存放到数组ch[0]到ch[4]中,ch[5]中存放'\0'。

如果在get函数中指定的n为20,而输入22个字符,则将输入流中前19个字符赋给字符数组ch中前19个元素,再加入一个'\0'。

get函数中第3个参数可以省写,此时默认为'\n'。下面两行等价:

  cin.get(ch,10,'\\n');
  cin.get(ch,10);

终止字符也可以用其他字符。如

  cin.get(ch,10,'x');

在遇到字符'x'时停止读取操作。

C++ getline()函数读入一行字符
getline函数的作用是从输入流中读取一行字符,其用法与带3个参数的get函数类似。即
    cin.getline(字符数组(或字符指针), 字符个数n, 终止标志字符)

[例] 用getline函数读入一行字符。

#include <iostream>
using namespace std;
int main( )
{
  char ch[20];
  cout<<"enter a sentence:"<<endl;
  cin>>ch;
  cout<<"The string read with cin is:"<<ch<<endl;
  cin.getline(ch,20,'/'); //读个字符或遇'/'结束
  cout<<"The second part is:"<<ch<<endl;
  cin.getline(ch,20); //读个字符或遇'/n'结束
  cout<<"The third part is:"<<ch<<endl;
  return 0;
}

程序运行情况如下:

enter a sentence: I like C++./I study C++./I am happy.
The string read with cin is:I
The second part is: like C++.
The third part is:I study C++./I am h

请仔细分析运行结果。用“cin>>”从输入流提取数据,遇空格就终止。因此只读取 一个字符'I',存放在字符数组元素ch[0]中,然后在ch[1]中存放'\0'。因此用"cout<<ch"输出时,只输出一个字符'I'。然后用cin.getline(ch, 20, '/')从输入流读取19个字符 (或遇结束)。请注意:此时并不是从输入流的开头读取数据。在输入流中有一个字符指针,指向当前应访问的字符。在开始时,指针指向第一个字符,在读入第一个字符'I'后,指针就移到下一个字符('I'后面的空格),所以getline函数从空格读起,遇到就停止,把字符串" like c++."存放到ch[0]开始的10个数组元素中,然后用"cout<<ch"输出这10个字符。注意:遇终止标志字符"/"时停止读取并不放到数组中。再用cin.getline(ch, 20)读19个字符(或遇'/n'结束),由于未指定以'/'为结束标志,所以第2个'/'被当作一般字符读取,共读入19个字符,最后输出这19个字符。

有几点说明并请读者思考:
1) 如果第2个cin.getline函数也写成cin. getline(ch, 20, '/''),输出结果会如何? 此时最后一行的输出为:

  The third part is: I study C++.

2) 如果在用cin.getline(ch, 20, '/')从输入流读取数据时,遇到回车键("\n"),是否 结束读取?结论是此时"\n"不是结束标志"\n"被作为一个字符被读入。

3) 用getline函数从输入流读字符时,遇到终止标志字符时结束,指针移到该终止标志字符之后,下一个getline函数将从该终止标志的下一个字符开始接着读入,如本程序运行结果所示那样。如果用cin.get函数从输入流读字符时,遇终止标志字符时停止读取,指针不向后移动,仍然停留在原位置。下一次读取时仍从该终止标志字符开始。这是getline函数和get函数不同之处。假如把例子程序中的两个cin.line函数调用都改为以下函数调用:

  cin.getline(ch, 20, '/');

则运行结果为:

enter a sentence: I like C++./I study C++./I am happy.
The string read with cin is: I
The second part is: like C++.
The third part is:  (没有从输人流中读取有效字符)

第2个cin. getline(ch, 20, '/')从指针当前位置起读取字符,遇到的第1个字符就是终止标志字符读入结束,只把"\0"存放到ch[0]中,所以用“cout<<ch”输出时无字符输出。

因此用get函数时要特别注意,必要时用其他方法跳过该终止标志字符(如用后面介绍的ignore函数,详情请查看:一些与输入有关的istream类成员函数),但一般来说还是用getline函数更方便。

4) 请比较用“cin<<”和用成员函数cin.getline()读数据的区别。用“cin<<”读数据时以空白字符(包括空格、tab键、回车键)作为终止标志,而用cin.getline()读数据时连续读取一系列字符,可以包括空格。用“cin <<”可以读取C++的标准类型的各类型数据(如果经过重载,还可以用于输入自定义类型的数据),而用cin.getline()只用于输入字符型数据。

时间: 2015-09-23

c++实现发送http请求通过get方式获取网页源代码

复制代码 代码如下: #include <stdio.h>#include <windows.h>#include <wininet.h>#define MAXSIZE 1024#pragma comment(lib, "Wininet.lib") void urlopen(_TCHAR*); int _tmain(int argc, _TCHAR* argv[]){    urlopen(_T("http://www.jb51.net&q

详解C语言gets()函数与它的替代者fgets()函数

在c语言中读取字符串有多种方法,比如scanf() 配合%s使用,但是这种方法只能获取一个单词,即遇到空格等空字符就会返回.如果要读取一行字符串,比如: I love BIT 这种情况,scanf()就无能为力了.这时我们最先想到的是用gets()读取. gets()函数从标准输入(键盘)读入一行数据,所谓读取一行,就是遇到换行符就返回.gets()函数并不读取换行符'\n',它会吧换行符替换成空字符'\0',作为c语言字符串结束的标志. gets()函数经常和puts()函数配对使用,puts

基于C语言EOF与getchar()的使用详解

大师级经典的著作,要字斟句酌的去读,去理解.以前在看K&R的The C Programming Language(SecondEdition)第1.5节的字符输入/输出,被getchar()和EOF所迷惑了.可能主要还是由于没有搞清楚getchar()的工作原理和EOF的用法.因此,感觉很有必要总结一下,不然,很多琐碎的知识点长时间过后就会淡忘的,只有写下来才是最好的方法. 其实,getchar()最典型的程序也就几行代码而已.本人所用的环境是DebianGNU/Linux,在其他系统下也一样.

C语言的getc()函数和gets()函数的使用对比

C语言getc()函数:从流中读取字符 头文件: #include <stdio.h> 函数getc()用于从流中取字符,其原型如下: int getc(FILE *stream); [参数]参数*steam为要从中读取字符的文件流. [返回值]该函数执行成功后,将返回所读取的字符. [说明]若从一个文件中读取一个字符,读到文件尾而无数据时便返回EOF.getc()与fgetc()作用相同,但在某些库中getc()为宏定义,而非真正的函数. [实例]下面的示例演示了getc()函数的使用,在程

基于C++ cin、cin.get()、cin.getline()、getline()、gets()函数的使用详解

1.cin 2.cin.get() 3.cin.getline() 4.getline() 5.gets() 6.getchar() 附:cin.ignore();  cin.get()//跳过一个字符,例如不想要的回车,空格等字符 1.cin>>          用法1:最基本,也是最常用的用法,输入一个数字: #include <iostream> using namespace std; main () {    int a,b;    cin>>a>&g

cin.get()和cin.getline()之间的区别

cin.getline()和cin.get()都是对输入的面向行的读取,即一次读取整行而不是单个数字或字符,但是二者有一定的区别. cin.get()每次读取一整行并把由Enter键生成的换行符留在输入队列中,比如: 复制代码 代码如下: #include <iostream>using std::cin;using std::cout;const int SIZE = 15;int main( ){cout << "Enter your name:";char

C语言实现类似wget的进度条效果

本文主要是类似wget的进度条的实现,实际就是转移符\r的使用,\r的作用是返回至行首而不换行 复制代码 代码如下: #include <stdio.h> #include <stdlib.h> #include <unistd.h> //类似wget的进度条的实现,实际就是转移符\r的使用,\r的作用是返回至行首而不换行 int main(int argc, char *argv[]) {     unsigned len = 60;     char *bar =

C++中getline()和get()的方法浅析

最原始的方法: 获取输入流最原始的形式就是cin>>(type) ,但是这种形式在碰到输入中有空格.制表符或者换行符的时候就会中断,值得注意的是中断后空格.制表符或者换行符还继续留在输入流中.所以最简单的,我们无法使用cin>>(type)的形式来读取包含空格的字符串,比如输入流中有一句:How are you?使用cin>>(type)是无法一次性读取出来的,鉴于此,getline()方法和get()方法便诞生了. getline()方法: getline()方法读取

Python linecache.getline()读取文件中特定一行的脚本

比如: Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ -->import linecacheprint linecache.getline('2.1_open.py', 4)将返回我上一节事例代码文件2.1_open.py的第4行文字,输出结果:f = open('/home/evergreen/桌面/test') 查看linecache中的实现(我

对比C语言中getc()函数和ungetc()函数的使用

C语言getc()函数:从流中读取字符 头文件: #include <stdio.h> 函数getc()用于从流中取字符,其原型如下: int getc(FILE *stream); [参数]参数*steam为要从中读取字符的文件流. [返回值]该函数执行成功后,将返回所读取的字符. [说明]若从一个文件中读取一个字符,读到文件尾而无数据时便返回EOF.getc()与fgetc()作用相同,但在某些库中getc()为宏定义,而非真正的函数. [实例]下面的示例演示了getc()函数的使用,在程

C语言中strlen() strcpy() strcat() strcmp()函数的实现方法

strlen函数原型:unsigned int strlen(const char *);返回的是字符串中第一个\0之前的字符个数. 1.strcat函数原型char* strcat(char* dest,const char* src); 进行字符串的拼接,将第二个字符串连接到第一个字符串中第一个出现\0开始的地方.返回的是拼接后字符的首地址.并不检查第一个数组的大小是否可以容纳第二个字符串.如果第一个数组的已分配的内存不够容纳第二个字符串,则多出来的字符将会溢出到相邻的内存单元. 2.str

浅谈C语言中strcpy,strcmp,strlen,strcat函数原型

实例如下: //strcat(dest,src)把src所指字符串添加到dest结尾处(覆盖dest结尾处的'\0')并添加'\0' char *strcat(char * strDest, const char *strSrc) { char *res=strDest; assert((strDest!=NULL)&&(strSrc!=NULL)); while(*strDest)strDest++; while(*strDest=*strSrc) { strDest++; strSrc

对比C语言中的setbuf()函数和setvbuf()函数的使用

C语言setbuf()函数:把缓冲区与流相关联 头文件: #include <stdio.h> 函数setbuf()用于将指定缓冲区与特定的文件流相关联,实现操作缓冲区时直接操作文件流的功能.其原型如下: void setbuf(FILE * stream, char * buf); [参数]stream为文件流指针,buf为缓冲区的起始地址. 如果参数buf 为NULL 指针,则为无缓冲,setbuf()相当于调用setvbuf(stream, buf, buf ? _IOFBF : _IO

对比C语言中execv相关的执行文件的三个函数

C语言execv()函数:执行文件函数 头文件: #include <unistd.h> 定义函数: int execv (const char * path, char * const argv[]); 函数说明:execv()用来执行参数path 字符串所代表的文件路径, 与execl()不同的地方在于execve()只需两个参数, 第二个参数利用数组指针来传递给执行文件. 返回值:如果执行成功则函数不会返回, 执行失败则直接返回-1, 失败原因存于errno 中. 错误代码:请参考 ex

简单对比C语言中的fputs()函数和fputc()函数

C语言fputc()函数:写文件函数(将一指定字符写入文件流中) 头文件: #include <stdio.h> 定义函数: int fputc(int c, FILE * stream); 函数说明:fputc 会将参数c 转为unsigned char 后写入参数stream 指定的文件中. 返回值:fputc()会返回写入成功的字符, 即参数c. 若返回EOF 则代表写入失败. 范例 #include <stdio.h> main() { FILE * fp; char a[

详细对比C语言中的chmod()函数和fchmod()函数

C语言chmod()函数:修改文件权限 头文件: #include <sys/types.h> #include <sys/stat.h> 定义函数: int chmod(const char * path, mode_t mode); 函数说明:chmod()会依参数mode 权限来更改参数path 指定文件的权限. 参数 mode 有下列数种组合: 1.S_ISUID 04000 文件的 (set user-id on execution)位 2.S_ISGID 02000 文

对比C语言中memccpy()函数和memcpy()函数的用法

C语言memccpy()函数:复制内存中的内容 头文件: #include <string.h> 定义函数: void * memccpy(void *dest, const void * src, int c, size_t n); 函数说明:memccpy()用来拷贝src 所指的内存内容前n 个字节到dest 所指的地址上.与memcpy()不同的是,memccpy()会在复制时检查参数c 是否出现,若是则返回dest 中值为c 的下一个字节地址. 返回值:返回指向dest 中值为c 的

简要对比C语言中的setgid()函数和setregid()函数

C语言setgid()函数:设置真实的组识别码 头文件: #include <unistd.h> 定义函数: int setgid(gid_t gid); 函数说明:setgid()用来将目前进程的真实组识别码(real gid)设成参数gid 值. 如果是以超级用户身份执行此调用, 则real.effective 与savedgid 都会设成参数gid. 返回值:设置成功则返回0, 失败则返回-1, 错误代码存于errno 中. 错误代码: EPERM:并非以超级用户身份调用, 而且参数gi

简要对比C语言中的truncate()函数与ftruncate()函数

C语言truncate()函数:改变文件大小 头文件: #include <unistd.h> 定义函数: int truncate(const char * path, off_t length); 函数说明:truncate()会将参数path 指定的文件大小改为参数length 指定的大小. 如果原来的文件大小比参数length 大, 则超过的部分会被删去. 返回值:执行成功则返回0, 失败返回-1, 错误原因存于errno. 错误代码: 1.EACCESS 参数path 所指定的文件无