• C++ 输入ctrl+z 不能再使用cin的问题


    问题介绍: 程序步骤是开始往容器里面写数据,以Ctrl+Z来终止输入流,然后需要输入一个数据,来判断容器中是否有这个数据。

    源代码如下:

     1 #include<iostream>
     2 #include<map>
     3 #include<string>
     4 #include<vector>
     5 using namespace std;
     6 int main()
     7 {
     8     map<string,vector<int> >my_map;
     9     string word;
    10     string word_to_find;
    11     vector<int> ivec;
    12     while(cin >> word)
    13        my_map[word].push_back(0);
    14 
    15     cout << "input a string you want to find:" << endl;
    16     
    17     cin >> word_to_find;
    18     map<string,vector<int> >::iterator it = my_map.find(word_to_find);
    19     if(it != my_map.end())
    20     {
    21         vector<int>::iterator it_vec = (it->second).begin();
    22         cout << it->first << endl;
    23         for(it_vec;it_vec != (it->second).end(); it_vec++)
    24             cout << *it_vec << " ";
    25         cout << endl;
    26     }
    27 }

    当在第12行输入ctrl+z终止输入流的时候,第17行的cin语句是失效的,应该是ctrl+z(文件结束符)默认程序是不再需要输入的,所以后面的cin语句就是失效的。

    cin语句为什么会失效?

         显然,直观的感受是ctrl+z引起cin失效。这里牵扯到一个概念:条件状态。IO标准库管理一系列条件状态(condition state)成员,用来标记给定的IO对象是否处于可用状态,或者碰到了哪种特定的错误。

         每个IO类定义了三个iostate类型的常量值,分别表示特定的位模式。badbit标志着系统级的故障,如无法恢复的读写错误。如果出现了该类错误,则此流通常不能再用了。如果出现的是可恢复的错误,如在希望获得数值型数据时输入了字符,此时设置failbit标志。eofbit是在遇到文件结束符时设置的,此时同时设置了failbit。流的状态由bad,fail,eof,good操作揭示。任意一个为true,则检查流本身将显示该流处于错误状态。

         经检验,运行上述代码,failbit设置为TRUE,而eofbit是为false,按理来说ctrl+z是文件结束符(不太确定),eofbit是为true的。

         要使流重新生效,可调用流的clear方法。这里使用cin.clear().

     1 #include<iostream>
     2 #include<map>
     3 #include<string>
     4 #include<vector>
     5 using namespace std;
     6 int main()
     7 {
     8     map<string,vector<int> >my_map;
     9     string word;
    10     string word_to_find;
    11     vector<int> ivec;
    12     while(cin >> word)
    13        my_map[word].push_back(0);
    14     
    15     cin.clear();  // 更改cin的状态标示符
    16     cin.sync();  // 清除缓存区的数据流
    17     cout << "input a string you want to find:" << endl;
    18     
    19     cin >> word_to_find;
    20     map<string,vector<int> >::iterator it = my_map.find(word_to_find);
    21     if(it != my_map.end())
    22     {
    23         vector<int>::iterator it_vec = (it->second).begin();
    24         cout << it->first << endl;
    25         for(it_vec;it_vec != (it->second).end(); it_vec++)
    26             cout << *it_vec << " ";
    27         cout << endl;
    28     }
    29 }
  • 相关阅读:
    STL 全排列
    Happy Programming Contest
    输入外挂
    Crazy Professor
    订票助手 12306
    我的e证空间 出入境证照可在家自拍啦!
    雨生红球藻 虾青素 寻找正规产品!
    CAR 汽车团购网站—广州
    3G路由器、无线接入点(无线AP)、无线路由器!
    微软 Lightswitch 发布 V2 Beta,引入新的逻辑层基础技术!
  • 原文地址:https://www.cnblogs.com/hubavyn/p/3996413.html
Copyright © 2020-2023  润新知