cin,cin.get()等异同点[面试题系列]

函数原型

  1. cin
  2. cin.get(void);cin.get(char&);cin.get(char *,int n);cin.get(char*,int n,char)
  3. getchar() = cin.get(void)
  4. cin.getline(char*,int n);cin.getline(char*,int n,char)
  5. getline(cin,string& line)

cin

  1. cin永远会跳过空白(空格、tab、enter)
  2. cin在遇到第一个类型不匹配的字符时会停止读取。对于int等类型的容器,cin的这个特性是更鲜明的。对于char等类型(char string vector<char>等),不存在类型不匹配的字符,因此只会按照第一点的原则,即使遇到空白时停止。因此空白更像是一种数据分割标志,而非数据本身。
  3. cin在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  4. 会返回输入流引用cin

cin.get(void)

  1. 从输入流取一个数据,并返回这个数据,而不是输入流引用cin

cin.get(char&)

  1. 从输入流取一个数据赋值给char
  2. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  3. 会返回输入流引用cin

cin.get(char*,int n)

  1. 从输入流中取数据,放入char*位置。
  2. 取完n-1个字符停止,最后一个字符补'\0'
  3. 遇到换行符也结束,换行符留在输入流中
  4. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  5. 会返回输入流引用cin

cin.get(char *,int n,char)

  1. 从输入流中取数据,放入char*位置。
  2. 取完n-1个字符停止,最后一个字符补'\0'
  3. 遇到char指定的字符也结束,该字符留在输入流中
  4. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  5. 会返回输入流引用cin

cin.getline(char*,int n)

  1. 从输入流中取数据,放入char*位置。
  2. 取完n-1个字符停止,最后一个字符补'\0'
  3. 遇到换行符也结束,换行符被丢弃
  4. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  5. 会返回输入流引用cin

cin.getline(char*,int n,char)

  1. 从输入流中取数据,放入char*位置。
  2. 取完n-1个字符停止,最后一个字符补'\0'
  3. 遇到char指定的字符也结束,该字符被丢弃
  4. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  5. 会返回输入流引用cin

getline(cin,string& line)

  1. 从输入流中取数据,放在line中
  2. 遇到换行符结束,换行符被丢弃
  3. 在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  4. 会返回输入流引用cin

相同点

  1. 除了cin.get(void),在遇到文件结尾时会设置eofbit,可使用cin.eof()查看;在没有成功取到数据时,会设置failbitt,可使用cin.fail()查看。
  2. 会返回输入流引用cin

区别

  1. cin.get(void)、cin.get(char&)用于取单个字符
  2. cin.get(char*,int n)、cin.getline(char*,int n)用于取整行字符串
  3. getline(cin,string& line)在<string>头文件中,可动态增容
相关推荐
点云SLAM2 小时前
PyTorch 中.backward() 详解使用
人工智能·pytorch·python·深度学习·算法·机器学习·机器人
only-qi3 小时前
146. LRU 缓存
java·算法·缓存
xuxie134 小时前
SpringBoot文件下载(多文件以zip形式,单文件格式不变)
java·spring boot·后端
重生成为编程大王4 小时前
Java中的多态有什么用?
java·后端
梁辰兴4 小时前
数据结构:排序
数据结构·算法·排序算法·c·插入排序·排序·交换排序
666和7774 小时前
Struts2 工作总结
java·数据库
中草药z4 小时前
【Stream API】高效简化集合处理
java·前端·javascript·stream·parallelstream·并行流
野犬寒鸦4 小时前
力扣hot100:搜索二维矩阵 II(常见误区与高效解法详解)(240)
java·数据结构·算法·leetcode·面试
zru_96024 小时前
centos 系统如何安装open jdk 8
java·linux·centos
菜鸟得菜4 小时前
leecode kadane算法 解决数组中子数组的最大和,以及环形数组连续子数组的最大和问题
数据结构·算法·leetcode