C++异常处理分析

C++异常处理基本语法:
代码如下:

#include <iostream>
using namespace std;int divide(int x, int y)
{if (y == 0) throw y;return x / y;
}void test01()
{//试着去捕获异常try{divide(10, 0);}/*catch (int){cout << "除数为0!" << endl;} */catch (int e){cout << "除数为" << e << "!" << endl;}
}int main()
{test01();return 0;
}
  1. C++异常机制跨函数
  2. C++异常必须处理

代码如下:

#include <iostream>
using namespace std;int divide(int x, int y)
{if (y == 0) throw y;return x / y;
}void test01()
{//试着去捕获异常try{divide(10, 0);}/*catch (int){cout << "除数为0!" << endl;} */catch (int e){cout << "除数为" << e << "!" << endl;}
}void callDivide(int x, int y)
{divide(x, y);
}void test02()
{try {callDivide(10,0);}catch (int e){cout << "除数为" << e << "!" << endl;}
}int main()
{/*test01();*/test02();return 0;
}

栈解旋
异常被抛出后,从进入try块起,这期间在栈上构造的所有对象,都会被自动析构。析构的顺序与构造的顺序相反,这一过程称为栈的解旋。

代码如下:

#include <iostream>
using namespace std;class Person
{
public:Person(){cout << "对象构建" << endl;}~Person() {cout << "对象析构" << endl;}
};int divide(int x, int y)
{Person p1, p2;if (y == 0) throw y;return x / y;
}void test01()
{//试着去捕获异常try{divide(10, 0);}/*catch (int){cout << "除数为0!" << endl;} */catch (int e){cout << "异常捕获"<< endl;}
}void callDivide(int x, int y)
{divide(x, y);
}int main()
{test01();return 0;
}

测试结果:
在这里插入图片描述

异常接口声明:

在这里插入图片描述
由于C++编译器,忽略C++异常规范,所有在VS可以编译通过运行,但是在linux是不行的。

代码如下:

#include <iostream>using namespace std;//这个函数只能抛出int,float,char三种类型异常,抛出其他的就报错
void func() throw(int ,float,char)
{throw "abc";
}//不能抛出任何异常
void func02() throw()
{throw - 1;
}//可以抛出任何异常
void func03() 
{throw - 1;
}int main()
{try {func();}catch (char * str){cout << str << endl;}catch (int e){cout << "异常" << endl;}catch (...){cout << "未知异常" << endl;}return 0;
}

C标准异常类使用举例和编写自己的异常类:

代码如下:

#include <iostream>
#include <stdexcept>
using namespace std;class  Person {
public:Person(){mAge = 0;}void setAge(int age){if (age < 0 || age > 100){throw out_of_range("年龄应该在0-100之间!");}this->mAge = age;}public:int mAge;
};void test01()
{Person p;try {p.setAge(1000);}/*catch (out_of_range e){cout << e.what() << endl;}*/catch (exception e){cout << e.what() << endl;}}class MyOutOfRange :public exception
{
public:MyOutOfRange(const char *error){pError = new char[strlen(error) + 1];strcpy(pError, error);}~MyOutOfRange(){if (pError != nullptr){delete[] pError;}}virtual const char *what() const{return pError;}public:char *pError;
};void fun02()
{throw MyOutOfRange("我自己的out_of_range!");}void test02()
{try{fun02();}catch (exception &e){cout << e.what() << endl;}
}int main()
{/*test01();*/test02();return 0;
}

继承在异常中的应用:
代码如下:

#include <iostream>
using namespace std;//异常基类
class BaseMyException
{
public:virtual void what() = 0;virtual ~BaseMyException(){}
};class TargetSpaceNullException :public BaseMyException
{
public:virtual void what(){cout << "目标空间空!" << endl;}~TargetSpaceNullException() {}
};class SourceSpaceNullException :public BaseMyException
{
public:virtual void what(){cout << "原空间为空!" << endl;}~SourceSpaceNullException(){}
};void copy_str(char *taget, const char *source)
{if (taget == nullptr){throw TargetSpaceNullException();}if (source == nullptr){throw SourceSpaceNullException();}int len = strlen(source) + 1;while (*source != '\0'){*taget = *source;taget++;source++;}
}int main()
{const char *source = "abcdefg";char buf[1024] = { 0 };try {copy_str(buf, source);}catch (BaseMyException &ex){ex.what();}cout << buf << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/310077.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java文件损坏_java – 损坏的文件处理

我想知道如果任何人有任何建议处理损坏的文件与Apache POI我试图打开一个文件&#xff0c;并收到此消息&#xff1a;Exception in thread "main" org.apache.poi.hssf.record.RecordInputStream$LeftoverDataException: Initialisation of record 0x1C left 2 bytes …

Harmonic Number (II) LightOJ - 1245(找规律?大数f(n)=n/1+n/2+n/3+......+n/n)

题意&#xff1a;让我们求f&#xff08;n&#xff09;n/1n/2n/3......n/n&#xff1b;同时注意n/i取整&#xff1b; 思路&#xff1a;首先我们先看数据的范围&#xff0c;n (1 ≤ n < 2 31)&#xff0c;数据范围太大&#xff0c;如果我们按 照题目中的代码直接暴力肯定超时…

陌陌的 Service Mesh 探索与实践

Service Mesh Virtual Meetup 是 ServiceMesher 社区和 CNCF 联合主办的线上系列直播。本期为 Service Mesh Virtual Meetup#1 &#xff0c;邀请了四位来自不同公司的嘉宾&#xff0c;从不同角度展开了 Service Mesh 的应用实践分享&#xff0c;分享涵盖来自陌陌和百度的 Servi…

C标准输入流

标准输入流对象cin&#xff0c;重点掌握的函数: cin.get()//一次只能读取一个字符 cin.get(一次参数)//读一个字符 cin.get(两个字符)//可以读字符串 cin.getline() cin.ignore() cin.peek() cin.putback() 标准输入流cin.get() 代码如下: #include <iostream> using n…

Harmonic Number(欧拉公式或技巧打表)LightOJ - 1234(求调和级数的和)

题意&#xff1a;求f(n)1/11/21/31/4…1/n (1 ≤ n ≤ 108).&#xff0c;精确到10-8 (原题在文末&#xff09; 知识点&#xff1a;调和级数(即f(n))至今没有一个完全正确的公式&#xff0c;但欧拉给出过一个近似公式&#xff1a;(n很大时) f(n)≈ln(n)C1/2*n 欧拉常数值&…

教你配置windows上的windbg,linux上的lldb,打入clr内部这一篇就够了

一&#xff1a;背景1. 讲故事前几天公众号里有位兄弟看了几篇文章之后&#xff0c;也准备用windbg试试看&#xff0c;结果这一配就花了好几天&#xff0c;(づ╥﹏╥)づ&#xff0c;我想也有很多跃跃欲试的朋友在配置的时候肯定会遇到这样和那样的问题&#xff0c;所以我觉得有必…

vue动态跟新layui的select_vue+layui实现select动态加载后台数据的例子

vuelayui实现select动态加载后台数据的例子发布时间&#xff1a;2020-09-18 22:51:36来源&#xff1a;脚本之家阅读&#xff1a;85作者&#xff1a;qq_26814945刚开始由于layui form渲染与vue渲染有时间差 有时会导致 select里面是空白的后来就想办法 等vue数据渲染完 再渲染la…

Rochambeau POJ - 2912 (枚举和加权并查集+路径压缩)找唯一裁判

题意&#xff1a;有n个人玩石头剪刀布&#xff0c;有且只有一个裁判。除了裁判每个人的出拳形式都是一样的。 a<b表示b打败a&#xff0c;ab表示a和b出拳一样&#xff0c;平手。a>b表示a打败b。 给出m个回合的游戏结果&#xff0c;问能否判断出谁是裁判&#xff1f;如果能…

C标准输出流

标准输入流对象cin&#xff0c;重点掌握的函数: cout.flush()//刷新缓冲区 cout.put()//向缓冲区写字符 cout.write()//二进制流的输出 cout.width()//输出格式控制 cout.fill() cout.set(标记) cout.flush() 代码如下: #include <iostream> using namespace std;void…

Autofac在.NET Core 中的使用

前言Autofac 是一款.NET IoC 容器 . 它管理类之间的依赖关系, 从而使应用在规模及复杂性增长的情况下依然可以轻易地修改 。.NET CORE 中也内置了依赖注入&#xff0c;但是有些情况下需要用到Autofac去进行依赖注入&#xff0c;Autofac支持的所有注入方式以外&#xff0c;还支持…

Aladdin and the Flying Carpet (素数打表+正整数的唯一分解定理,找因数对)

题目大意&#xff1a;给两个数a&#xff0c;b&#xff0c;求满足c*da且c>b且d>b的c,d二元组对数&#xff0c;(c,d)和(d,c)属于同一种情况 题目分析&#xff1a;根据唯一分解定理先将a唯一分解&#xff0c;则a的所有正约数的个数为ans (1 a1) * (1 a2) *...(1 an) 因为…

C++文本文件操作和二进制文件读写

文本文件操作: 代码如下: #include <iostream> #include <fstream> using namespace std;void test01() {const char *fileName "C:\\Users\\Tom\\Desktop\\hhh.txt";//ifstream ism(fileName, ios::in);//只读方式打开文件ifstream ism;ism.open(file…

java类结构工具_java类层次结构图工具

Java主类结构_计算机软件及应用_IT/计算机_专业资料。Java主类结构 谢谢大家! Java主类结构 谢谢大家! 申请认证 文档贡献者 胸兢谙韶硛蠌 中西医 59981 ......知识结构类思维导图模板:java知识结构。{"code":&...所有这些都遵从 Spring 的通用事务和 DAO 异常层…

详解.NET Core 依赖注入生命周期

前言.NET Core 自带依赖注入框架&#xff0c;支持三种不同生命周期的注入模式&#xff1a;Singleton 单例模式Scoped 区域模式Transient 瞬时模式但是常常不知道什么时候使用哪种模式才最合适&#xff0c;接下来我就用代码详细解读一下三种模式代码示例首先新建.NET Core API…

[C++STL]string容器用法介绍

string构造函数 代码如下: #include <iostream> #include <string> using namespace std;void test01() {string s1;cout << "s1 " << s1 << endl;const char *str "hello world";string s2(str);cout << "s2…

LightOJ-1220 Mysterious Bacteria (素数打表+欧几里得算法+唯一分解定理)给出x,求x=a^p,最大的指数

题目大意&#xff1a; x b^p, x只有一个因子的p次幂构成 如果24 2^3*3^1&#xff0c;p应该是gcd(3, 1) 1,即24 24^1 324 3^4*2^2(3^2*2)^2,p应该是gcd(4, 2) 2,即324 18^2 所以p gcd(x1, x2, x3, ... , xn){欧几里得算法求取最大公约数}; *本题有一个坑&#xff0c;就…

致敬平凡的程序员--《SOD框架“企业级”应用数据架构实战》自序

“简单就是美”“平凡即是伟大”上面两句话不知道是哪位名人说的&#xff0c;又或者是广大劳动人民总结的&#xff0c;反正我很小的时候就常常听到这两句话&#xff0c;这两句话也成了我的人生格言&#xff0c;而且事实上我也是一个生活过得比较简单的平凡人物&#xff0c;当然…

[C++STL]vector容器用法介绍

代码如下&#xff1a; #include <iostream> #include <string> #include <vector> using namespace std;void printVector(vector<int >&v) {for (vector<int>::iterator it v.begin(); it ! v.end(); it){cout << *it << &qu…

跟沈剑学习如何带领技术团队作战

【学习笔记】| 作者/Edison Zhou这是恰童鞋骚年的第229篇原创文章小编Edison在阿里云开发者社区上看到了58集团技术VP大佬沈剑关于如何带领技术团队作战的一个直播分享&#xff0c;因此在站地铁的上下班路上学习完了整个录播视频&#xff0c;整理总结下此文作为学习笔记&#x…

拓展欧几里得小结(初级理解)

什么是拓展欧几里得&#xff1f;简单的说&#xff0c;就是求关于x,y的方程 ax by gcd(a,b) 的所有整数解 现在我们令g gcd(a,b)则方程变成了ax by g 假如我们现在知道了关于这个方程的一个特解x0, y0&#xff0c;我们就可以用一种方法求出所有的整数解。 说的比较模糊&am…