博客
关于我
cin处理错误输入(clear,ignore,sync)
阅读量:609 次
发布时间:2019-03-12

本文共 312 字,大约阅读时间需要 1 分钟。

当代码是输入整数,而实际输入是非法字符(如字母)时,程序就会挂掉。

这时需要重置cin标识和清空缓冲区才行。

示例:

cin >> r >> c;	if (!cin) //当输入失败(比如输入的不是整数)时,必须先重置cin,然后手动清空cin的缓冲区,然后才能重新输入	{		cin.clear(); //这2个函数用来处理错误输入		cin.ignore();//清空cin缓存区		//cin.sync();		return play0();	}

clear函数是清空cin标识的,cin标识是输入错误时产生的,要手动清除才能继续输入。

ignore和sync函数都可以用来清空缓冲区,这2个函数有区别,但是区别不大。

转载地址:http://cpoxz.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0049---阶段内容梳理
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0051---Netty核心模块2
查看>>
Netty工作笔记0052---Pipeline组件剖析
查看>>
Netty工作笔记0053---Netty核心模块梳理
查看>>
Netty工作笔记0054---EventLoop组件
查看>>
Netty工作笔记0055---Unpooled应用实例1
查看>>
Netty工作笔记0056---Unpooled应用实例2
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0058---Netty群聊系统客户端
查看>>
Netty工作笔记0059---Netty私聊实现思路
查看>>
Netty工作笔记0060---Netty心跳机制实例
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0061---Netty心跳处理器编写
查看>>
Netty工作笔记0062---WebSocket长连接开发
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
vue样式穿透 ::v-deep的具体使用
查看>>
Netty工作笔记0065---WebSocket长连接开发4
查看>>
Netty工作笔记0066---Netty核心模块内容梳理
查看>>
Vue基本使用---vue工作笔记0002
查看>>