C++中限定输入整形,输入字符串如何处理异常[通俗易懂]

C++中限定输入整形,输入字符串如何处理异常

大家好,又见面了,我是全栈君。

在C++中有时候我们会有一定的需求,需要限定用户只能够输入整形数字的时候。但是我们都能够知道用户哪里懂那么多,哪里管那么多,都是想要尝试一下的,那么这时候我们就必须需要对输入进行一定的处理了,不然随时有可能导致系统奔溃,那可是不行的喔。

#include "iostream"
using namespace std;

int main()
{ 
   
	int i_a;  // 接受用户输入整形内容
	cout << "input a int:";  // 提示信息
	cin >> i_a;  
	cout << "input:" << i_a << endl;;
	system("pause");
	return 0;
}

正常来说,这样子就能够满足我们的要求了,但是真的就那么简单吗?
你能够确保你的客户都是高智商吗?他们都会按照你的提示进行输入吗?
答案当然是:不可能,用户是什么都有可能做的,你必须保证你的系统,你的代码容错性能足够强大,才能够让傻瓜用户多能够简单上手。那么我们必须对我们的代码进行修改,使得代码的容错性能足够强大,才能够使得自己的代码足够牛逼。

话不多说,上手吧。首先我们需要对用户输入的内容进行检测,接受用户输入的(使用一个临时的字符串进行接受),接受到的输入进行字符串转换整形,是否能够正确转换,能够正确转换就说明用户输入的是整形,是一个正确的输入,不能够转换说明输入的内容有问题,给出提示,让用户重新输入。

#include "iostream"
#include "regex"
using namespace std;

bool IsRegexInput(string str1)          // 使用正则表达式进行匹配,
{ 
   
	bool flag;
	flag = true;
	regex r("\\d{1,3}");
	while (!(flag = regex_match(str1, r)))
	{ 
   
		return flag;
	}
	return flag;
}

int main()
{ 
   
	int i_a;
	string str;
	cout << "input a int:"; 
	cin >> str;
	while (!IsRegexInput(str))   // 判断输入的内容是否为整形
	{ 
   
		cout << "输入内容格式有误,请输入数字:";
		cin >> str;
	}
	i_a = atoi(str.c_str());     //输入没有问题,进行字符串转换为整形

	cout << "input:" << i_a << endl;
	system("pause");
	return 0;
}

使用正则表达式进行匹配用户输入的内容,就能够使得输入的内容是我们需要的内容了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115097.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何生成lib文件_bin文件和mcs文件

    如何生成lib文件_bin文件和mcs文件看到一篇文章可以添加crc文章链接:http://blog.csdn.net/Simon223/article/details/105724950感觉应该可以可以添加一些自己的其他信息。先做个标记吧,后面再来学keil官网的摘抄信息:https://www.keil.com/support/docs/3806.htmµVISION:CRCExampleInformationinthisknowledgebasearticleappliesto:MDK-ARM5.00o

    2022年10月20日
    1
  • 前端vue面试题2020及答案_c++ 面试题

    前端vue面试题2020及答案_c++ 面试题总结出来的Vue面试题,持续更新…

    2025年10月6日
    2
  • Java程序设计(高级及专题)- 类的加载和反射[通俗易懂]

    Java程序设计(高级及专题)- 类的加载和反射[通俗易懂]Java程序设计(高级及专题)- 类的加载和反射

    2022年4月22日
    52
  • 视频编解码基本流程

    视频编解码基本流程视频编解码基本框架

    2022年7月13日
    15
  • GBDT算法梳理_gbdt分类

    GBDT算法梳理_gbdt分类集成算法大致分为两类:Boosting(迭代)和Bagging(装袋)。在前面的博客中,有提到,存在强依赖关系、必须串行生成的序列化方法,代表算法是Boosting,不存在强依赖关系、可同时生成的并行化方法,代表算法有Bagging、RandomForest。其中Boosting集成算法的典型代表算法有Adaboost,GBDT(GradientBoostingDecisionTree),…

    2022年10月12日
    2
  • 初步了解印度数学速算法

    初步了解印度数学速算法印度也是IT发达的国家;初步了解,印度的数学自己有一套东西,有的和我们从小学的有很大区别;它的速算法,有的计算看一眼就能给出答案;这东西练一下也许能帮助减低脑力劳动强度;大家有兴趣自己研究;先初步了解一下;下图,一看就给出答案;它的算法是,14加3得17,扩大10倍170,再加上3*4的结果12,最后结果182;对于十位上的数字相同,两位数乘两位数的算法:如:15*16(1)15+6=21(2)21*10=210(3)5*6=30(4)210+30=240…

    2022年5月23日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号