一般在写程序的时候总会因为一些逻辑的疏忽,导致代码运行与预期结果不符,这时候就需要通过调试去寻找其中的逻辑漏洞,这是一件很麻烦的事情,所以不如在平时写代码时就加入一些可能出错情况的条件判断,并给出相应提示;将这些提示打印输出,这样就可以很快的排除一些出错的情况,例如出入不合法,数组访问越界,内存开辟不合理,指针为空的情况.
在纯c语言中他使用的是传统的处理错误的方式,入错误情况报一个错误码,然后通过这个错误码去查找相关错误的具体情况,但是这样的处理错误方式有缺陷,就是一些函数他的返回值本身可能就和错误码很相似,所以有可能发生错误码与正常值混淆的可能,还有就是一些一层层函数调用的错误吗返回,当最里面的函数报错时返回错误码,然后一层层返回错误码,这很麻烦.
于是在c++中有了抛异常的错误处理方式,就是在满足错误条件的地方直接抛出一个异常代码,然后在捕获这个异常,这个抛异常有两个特点解决了上面的情况.1:跑异常时可以抛出任意类型的异常,这样就可以用一个自定义类去封装这个异常,就不会发生像上面说的异常与正常返回值混淆的情况了,
2:一旦发现异常抛出就会停止继续向下执行程序,知道执行捕获异常的代码阶段.这样就不会发生将异常一层一层返回的麻烦事了.
下图中一个是抛出整形的异常,一个是捕捉系统的vector访问越界的异常:
可以看到用try框出一个捕捉一场的范围,然后用catch捕捉特定类型的异常,所以这里catch可以与多个,并且能捕获各种类型的异常,也有可能抛出了异常但是没有捕获,所以一般都会在最后加一个...来捕获未知类型的异常.
c++中库里面有自带的异常库,在平时写代码时也要自己手动定义一些异常捕获.上面第一个就是用户手动抛出的异常类型,第二个是自带的异常.
然而在生活实际中可能一个项目要很多个人去写,每个人都报出不同的异常,会很麻烦,因为不知道要捕获什么异常,所以用的是继承体系捕获异常.
首先统一一个异常的基类,成员变量可以有异常码和异常的大概描述.
然后是一个虚函数,最好是纯虚函数,因为一定要用多态去捕获异常,所以这个虚函数必须重写.用what函数去详细描述异常情况.
可以看到,学生和老师共同继承了这个异常基类,当需要抛异常时抛出学生或老师的异常,最后用基类的引用去接收这个异常,最后只需要打印基类的异常数据就会发生多态抛出不同的异常.
标签:函数,抛出,捕获,错误码,基类,异常 From: https://www.cnblogs.com/qjwxlj/p/17415112.html