C++ 异常基本语法

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;class MyException
{
public:void printError(){cout << "我自己的异常类的错误" << endl;}
};class Person
{
public:Person(){cout << "Person的构造函数" << endl;}~Person(){cout << "Person的析构函数" << endl;}};int myDivide(int a , int b)
{if ( b == 0){//return -1; //C语言处理异常缺陷在于  返回的值 没有统一,返回的值可以是异常的结果,也可以是正确的结果//抛出异常//throw 1;//throw 3.14;//throw 'a';//栈解旋: 从try代码块开始起,到 throw抛出异常前,所有栈上的对象都被释放掉,//	       释放的顺序和构造的顺序是相反的,这个过程称为栈解旋Person p1;Person p2;throw MyException(); //抛出一个 MyException 匿名对象}return a / b;}void test01()
{int a = 10;int b = 0;//尝试执行一段 可能会出现异常的代码try{int ret = myDivide(a, b);cout << "ret 结果为: " << ret << endl;}catch (int ) //捕获异常{cout << "int类型的异常的捕获" << endl;}catch (double) {//捕获到double后 不想处理这个异常,想继续向上抛出这个异常throw;cout << "double类型的异常的捕获" << endl;}catch (MyException e){e.printError();}catch (...){cout << "其他类型异常的捕获" << endl;}}int main(){try{test01();}catch (int) //异常必须有人要处理,如果没有任何的处理,程序会自动调用一个terminate函数,让程序中断掉{cout << "main函数中的 int类型的异常的捕获" << endl;}catch (...){cout << "mian函数中的 其他类型异常的捕获" << endl;}system("pause");return EXIT_SUCCESS;
}

2异常的基本语法
2.1三个关键字 try throw catch
2.2try 试图执行一段可能会出现异常的代码
2.3throw出现异常后 抛出异常的关键字 throw + 类型
2.4catch 捕获异常 catch(类型)
2.5如果想捕获其他类型的异常 catch( … )
2.6如果捕获到的异常不想处理,想继续向上抛出 throw
2.7异常必须要有人处理,如果没有处理,程序会自动调用 terminate函数,使程序中断
2.8可以抛出一个自定义类型的异常 myException

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

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

相关文章

文字常量区和栈区考点

求以下程序输出结果 #include <stdio.h>char * fun1() {char * str "hello";return str; }char * fun2() {char str[] "world";return str; } int main() {printf("%s\n", fun1()); printf("%s\n", fun2()); return 0; }结…

C++ 异常变量的生命周期

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;class MyException { public:MyException(){cout << "MyException构造函数调用" << endl;}MyException(const MyException & e){cout << "MyException拷贝…

判断栈的压入和弹出

序列1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5是压栈序列。序列 4&#xff0c;3&#xff0c;5&#xff0c;1&#xff0c;2是弹出序列。判断第二个是不是弹出序列 三步走 如果下一个弹出的数字刚好是栈顶数字&#xff0c;直接弹出如果不在栈顶&#xff0c;就一直…

C++ 多态在异常中的使用

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;//异常 基类 class BaseException { public:virtual void printError() 0; };//空指针 异常 class NULLPointException :public BaseException { public:virtual void printError(){cout <…

一条语句判断数x是否2的n次幂.求取二进制1的个数

一条语句判断数x是否2的n次幂 return &#xff01;(x & (x - 1)); 求取十进制数字元素1的个数 int fun(int x) { int count 0; int i, j, k; /方法2 负数不可计算&#xff0c;需要改进/ while (x ! 0){ if (x & 1 1) count; x x >> 1; } /方法1/ while (x …

C++ 标准输入流01

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std;/* cin.get() //一次只能读取一个字符 cin.get(一个参数) //读一个字符 cin.get(两个参数) //可以读字符串 cin.getline() cin.ignore() cin.peek() cin.putback() */void test01() {//cin.get(…

动态规划学习笔记1

求连续子数组的最大和问题 代码不重要&#xff01;重要的是思想过程(括弧 好难啊&#xff01;&#xff01;&#xff01;) 输入的数组为{1&#xff0c;-2&#xff0c;3&#xff0c;10&#xff0c;-4&#xff0c;7&#xff0c;2&#xff0c;-5}&#xff0c;和最大的子数组为{3&…

C++ 文件读写操作01

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std; //文件读写的头文件 #include <fstream>//1、写文件 void test01() {//参数 1 文件路径 参数2 打开方式//ofstream ofs("./test.txt", ios::out | ios::trunc);ofstream …

动态规划学习笔记2

题目描述&#xff1a; 在一个mn的棋盘的每一格都放有一个礼物&#xff0c;每个礼物都有一定的价值&#xff08;价值大于0&#xff09;。你可以从棋盘的左上角开始拿格子里的礼物&#xff0c;并每次向右或者向下移动一格直到到达棋盘的右下角。给定一个棋盘及其上面的礼物&…

C++ i/o类库中 常用流类

类名 作用 在哪个头文件中声明 ios 抽象基类 iostream ------------------------------------------------------------------- istream 通用输入流和其他输入流的基类 iostream ostream 通用输出流和其他输出流的基类…

动态规划学习笔记3

某工厂预计明年有A、B、C、D四个新建项目&#xff0c;每个项目的投资额Wk及其投资后的收益Vk如下表所示&#xff0c;投资总额为30万元&#xff0c;如何选择项目才能使总收益最大&#xff1f; Project Wk Vk A 15 12 B 10 8 C 12 9 D 8 5 声明一个 二维数组 m[…

C++ STL 初步介绍01

STL 提供了6大组件&#xff0c;彼此之间可以组合套用&#xff0c;这6大组件分别是&#xff1a; 容器&#xff0c;算法&#xff0c;迭代器&#xff0c;仿函数&#xff0c;适配器&#xff0c;空间配置器 简单介绍&#xff1a; 容器&#xff1a;各种数据结构&#xff0c;入vector…

二叉树的层序遍历,前序遍历(递归,非递归),中序遍历(递归,非递归),后续遍历(递归,非递归)

文章目录二叉树的层序遍历前序遍历递归版本非递归版本中序遍历递归版本非递归版本后序遍历递归版本非递归版本二叉树的层序遍历 void printTree(BinaryTree* arr[]) {queue<BinaryTree*> rel; rel.push(arr[0]);while (!rel.empty()){BinaryTree* front rel.front();pr…

C++ STL 三大组件(容器|算法|迭代器) 初步使用01

#include <iostream> #include <string> #include <algorithm> // 使用算法 需要引入的头文件 #include <vector>using namespace std;void callback(int i) {cout << i << endl; }void test1() {// 操作内置类型vector<int> v;for …

内存碎片产生原因及解决办法

来源&#xff1a;知乎链接&#xff1a;https://www.zhihu.com/question/51836333/answer/145693402内存碎片通常分为内部碎片和外部碎片&#xff1a; 1. 内部碎片是由于采用固定大小的内存分区&#xff0c;当一个进程不能完全使用分给它的固定内存区域时就产生了内部碎片&…

C++ STL string 简单使用

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std; #include <string> #include <stdexcept> /* string 构造函数 string();//创建一个空的字符串 例如: string str; string(const string& str);//使用一个string对象初始化另一…

KMP算法的举例加图解

文章出处&#xff1a;阮一峰&#xff0c;进行重新排版整理 举例来说&#xff0c;有一个字符串"BBC ABCDAB ABCDABCDABDE"&#xff0c;我想知道&#xff0c;里面是否包含另一个字符串"ABCDABD"&#xff1f; 首先&#xff0c;字符串"BBC ABCDAB ABCDAB…

C++ STL 容器之 deque简单使用

#define _CRT_SECURE_NO_WARNINGS #include<iostream> using namespace std; #include <deque> #include <algorithm> /* deque构造函数 deque<T> deqT;//默认构造形式 deque(beg, end);//构造函数将[beg, end)区间中的元素拷贝给本身。 deque(n, elem…

进程间通讯的四种方式

文章目录共享内存信号管道消息队列通信方法 无法介于内核态与用户态的原因 管道&#xff08;不包括命名管道&#xff09; 局限于父子进程间的通信。 消息队列 在硬、软中断中无法无阻塞地接收数据。 信号量 无法介于内核态和用户态使用。 共享内存 需要信号量辅助&#xff0c;而…