温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++中怎么使用try和catch捕获异常

发布时间:2021-11-29 17:58:38 来源:亿速云 阅读:604 作者:iii 栏目:大数据

这篇文章主要介绍“C++中怎么使用try和catch捕获异常”,在日常操作中,相信很多人在C++中怎么使用try和catch捕获异常问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++中怎么使用try和catch捕获异常”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

异常处理

使用try和catch捕获异常

  try和catch是最重要的C++关键字。要捕获语句可能引发的异常,可将它们放在try块中,并使用catch块对try块可能引发的异常进行处理:

void somefunc(){    try    {        int* pNumber=new int;        *pNumber=999;        delete pNumber;    }    catch(……)  //catches all exceptions    {    cout<<"Exception in somefunc(),quitting"<<endl;    }}

catch(……)捕获未被其他catch块显示捕获的所有异常。
自定义异常类应继承std::exception,这让你能够重用捕获std::exception异常的所有catch()块 

编写优秀的C++代码

• 给变量指定(无论是对您还是其他人来说都)有意义的名称。值得多花点时间给变量取个好名。• 对于int、float等变量,务必进行初始化。

• 务必将指针初始化为NULL或有效的地址———如运算符new返回的地址。

• 使用数组时,绝不要跨越其边界。跨越数组边界被称为缓冲区溢出,可导致安全漏洞。

• 不要使用C风格字符串(char*'),也不要使用strelen()和strcopy()等函数。std::string更安全,还提供了很多有用的方法,如获取长度、进行复制和附加的方法。

• 仅当确定要包含的元素数时才使用静态数组。如果不确定,应使用std::vector等动态数组。

• 声明和定义接受非 POD 类型作为输入的函数时,应考虑将参数声明为引用,以免调用函数时执行不必要的复制步骤。

• 如果类包含原始指针成员,务必考虑如何在复制或赋值时管理内存资源所有 权,即应考虑编写复制构造函数和赋值运算符。

• 编写管理动态数组的实用类时,务必实现移动构造函数和移动赋值运算符,以改善性能。

• 务必正确地使用const。理想情况下,get()函数不应修改类成员,因此应将其声明为const函数。同样,除非要修改函数参数包含的值,否则应将其声明为const引用。

• 不要使用原始指针,而应尽可能使用合适的智能指针。

• 编写实用类时,务必花精力实现让它使用起来更容易的运算符。

• 在有选择余地的情况下,务必使用模板而不是宏。模板不但是通用的,还是类型安全的。

• 编写类时,如果其对象将存储在诸如vector和list等容器中,或者被用作映射中的键,务必实现运算符<,它将用作默认排序标准。如果您编写的lambda表达式很长,应考虑转而使用函数对象,即实现了operator()的类,因为函数对象可重用,且只有一个地方需要维护。

• 绝不要认为运算符new肯定会成功。对于分配资源的代码,务必处理其可能引发的异常,即将其放在try块中,并编写相应的catch()块。

• 绝不要在析构函数中引发异常。

到此,关于“C++中怎么使用try和catch捕获异常”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI