• C++中的字符串输入输出函数详解


    常见的输入问题:
    1、直接用cin输入(当然可以使用cout直接输出):
      1)string s;
        cin >> s; //只接收回车键和空格前面所输入的字符!!!!!
        一旦输入空格,cin将空格视为回车键,将会将后面的字符赋予后续有输入cin函数的变量中,如下面的a,故一定确保输入无空格!!
      2)char a[10];
        cin >> a; //同样,只接收回车键和空格前面所输入的字符!!!!!
        一旦输入空格,cin将空格视为回车键,将会将后面的字符赋予后续有输入cin函数的变量中,如下面的a,故一定确保输入无空格!!
        同样:(以下情况是一样的)
          char *b =a;
          cin >> b;

    2、使用空格为间隔输入多个数字或字符(与scanf功能一样)
      1)int a,b,c;
        cin >>a>>b>>c; //可以直接输入a,b,c的值,中间用空格[n个也行]或者回车键间隔都可以!!!
      2)
        char a, b;
        cin>>a>>b; //可以直接输入a,b的值,中间用空格[n个也行]或者回车键间隔都可以!!!但无法将空格字符赋予a,b

    输入函数
      string str/line;

    1)cin
      cin >> line
        //遇到回车键停止输入,按空格输出,
      空格、回车等会被丢弃(这些还在缓冲区中,下次若用cin会自动丢弃),下次又会读取流中剩下的内容。(对于要输入一个字符串如果用cin>>input;这样的方法来输入一个字符串,则遇到空白换行,制表之类的,输入都会停止)因为从流中读入数据保存到string中,string会遇到空格就停止录入。这样当我们输入一行带空格的字符串,就要考虑getline函数,从流中读入一行字符串.


    2)getline
      string line;
      getline(cin,line);//按回车键结束输入
      getline(cin,line,'#');
        //输入一串字符(不管多少个回车键),只要是在‘#’号之 前的字符都会读取并保存

      get与getline区别不是很大,但一个明显的区别是get遇到' '字符后便返回,这时 'n '还在缓冲区中,所以下次读出来的将是 ' ',而getline遇到' '也返回,但它会把 ' '从缓冲区里移除掉,所以很多时候用getline方便些。

    3)cin.get()
      用法1: cin.get(字符变量名)可以用来接收字符
        char ch;
        ch = cin.get(); //只接受一个字符


      用法2:cin.get(字符数组名,接收字符数目)用来接收一行字符串,可以接收空格
        char a[20];
        cin.get(a,20);


      注意:
        cin.get()会将回车键存储在缓存中,若后面还有cin.get()函数,则该函数会将缓存中的回车键取出并赋予后面的输入变量中,故,使用了cin.get()函数就一定后面要加getchar(),将回车键读取并丢弃!!!!!!!!!

    4)cin.getline()
      //接受一个字符串可以接受空格并输出
      char m[20];
      cin.getline(m,5);
      输入:jkjkjkjkkjkjkjkj
      输出:jklj //第5个字符默认添加''

    5)gets()【c++11已弃用!!!】
      //接受一个字符,可以接受空格并输出,需包含头文件#include<string>
      char ch;
      gets(ch);

    3)getchar()
      getchar()是stdio.h中的库函数,它的作用是从stdin流中读入一个字符,也就是说,如果stdin有数据的话不用输入它就可以直接读取了,第一次getchar()时,确实需要人工的输入,但是如果你输了多个字符,以后的getchar()再执行时就会直接从缓冲区中读取了。
    故一般用getchar()来清除缓存中的字符

    4)输入强行退出
    Ctrl + Z 或输入EOF再按回车键

  • 相关阅读:
    剑指offer--38.左旋转字符串
    剑指offer--37.和为S的两个数字
    剑指offer--35.数组中只出现一次的数字
    剑指offer--34.数字在排序数组中出现的次数
    剑指offer--33.丑数
    剑指offer--36.整数中1出现的次数(从1到n整数中1出现的次数)
    剑指offer--32.把数组排成最小的数
    剑指offer--31.二叉树中和为某一值的路径
    剑指offer--30.二叉搜索树的后序遍历序列
    剑指offer--29.从上往下打印二叉树
  • 原文地址:https://www.cnblogs.com/zzw1024/p/10502011.html
Copyright © 2020-2023  润新知