草庐IT

catch-safeguarding

全部标签

C++11 复制省略号和异常(catch 参数)

在代码审查之后,我们在try/catchblock中遇到了复制elison的问题。阅读此页面后:cppreferenceguide特别是这一段:Whenhandlinganexception,iftheargumentofthecatchclauseisofthesametype(ignoringtop-levelcv-qualification)astheexceptionobjectthrown,thecopyisomittedandthebodyofthecatchclauseaccessestheexceptionobjectdirectly,asifcaughtbyrefer

c++ - 为什么编译器不提示 catch 子句?

此代码生成C2248:'A::B::ExceptionB':无法访问在VS2008中的'classA::B'中声明的私有(private)类。#includeclassA{classExceptionA{};classB{classExceptionB{};public:B();};public:A(int);};A::B::B(){throwExceptionB();}A::A(inti){i%2?throwExceptionA():throwA::B::ExceptionB();//C2248!!}intmain(){try{Aa(3);}catch(A::ExceptionA&)

c++ - 在构造函数 C++ 中处理 Try-catch block

我面临这样一种情况,我需要在构造函数中使用try-catchblock。特别是,构造函数尝试调用tryblock中的函数,如果失败,它将调用另一个函数来设置一些值。在这两种情况下,构造函数都应该正确地创建对象,并且在这两种情况下它都必须在结束之前调用一些其他方法。情况如下:classA{A(inti){try{setDevice(i);}catch(DeviceException&ex){setDevice(0);throwex;}otherMethod();}}但是,如果在tryblock中发生错误,则不会调用otherMethod(),因为执行在catchblock内结束,我不能像

c++ - C++ 如何处理 try catch block 中的赋值?

我使用clang分析器检查我的C++代码是否存在缺陷和错误。我有以下构造:#include#includedoublesomethingThatMayThrow()throw(std::exception){if(rand()%2){throwstd::exception();}return5.0;}intmain(){doublevalue=2.0;try{value=somethingThatMayThrow();}catch(conststd::exception&){std::cout分析器现在提示变量value的初始值从未被读取。但是,很明显,当且仅当tryblock中出现异

c++ - boost::phoenix try_catch_all 构造编译失败

我正在编写用于日期解析的boost::spirit::qi语法。#include#include#includetemplatestructdate_rfc1123_grammar:boost::spirit::qi::grammar{typedefboost::gregorian::datevalue_type;date_rfc1123_grammar():date_rfc1123_grammar::base_type(date){namespaceqi=boost::spirit::qi;namespacephx=boost::phoenix;usingqi::_pass;usin

c++ - 在 catch block 中抛出异常会导致两个异常同时发生吗?

这个问题在这里已经有了答案:Nestedtry...catchinsideC++exceptionhandler?(2个答案)关闭去年。考虑以下C++代码:classMyException{};voidsomeFunction(){try{///...codethatmaythrow}catch(std::exception&e){throwMyException();}}问题异常e是在catchblock的开头还是在catchblock的末尾被吸收?在第二种情况下,抛出新的异常会导致两个异常在运行中,这不是我想要的。我想吸收std::exception并开始我自己的类型之一。

c++ - 地址 sanitizer : "SEGV on unknown adress" when using throw-catch and printf

当我扔东西时,例如一个int或一个charconst*,并使用printf检查错误,我得到一个AddressSanitizerError。我无法在网上找到任何类似的东西,而且我的代码示例非常基础,以至于我真的不明白它怎么可能会产生错误。精简代码示例:#includeintmain(){try{throw42;}catch(intmsg){printf("%d\n",msg);}return0;}运行代码时的控制台输出:ASAN:SIGSEGV===================================================================16533=

c++ - 使用C++ catch框架验证assert语句

是否可以使用C++CATCH框架来验证assert语句是否正确识别无效前提条件?//SourcecodevoidloadDataFile(FILE*input){assert(input!=NULL);...}//TestcodeTEST_CASE("loadDataFileassertsoutwhenpassedNULL","[loadDataFile]"){loadDataFile(NULL)//NowwhatdoIlookfor?} 最佳答案 假设您的示例的第一部分是被测源代码,第二部分是单元测试,那么您需要选择如何处理:一些

c++ - 是否有 "safe"方法来声明 lippincott 函数,以便它不会在 catch 之外被调用?

ALippincottfunction是一个将异常转换为返回码的函数,可以在来自另一种不支持异常的语言(例如C)的回调中安全地处理该返回码。这样的函数,因为它们故意使用throw没有参数,因此重新抛出最近捕获的异常,不能在catch的上下文之外调用block。我想知道现代C++(c++17或c++20)是否有任何声明机制来专门识别此类函数,并确保只从catch的上下文中调用函数block(或来自另一个此类函数的上下文),如果从任何其他上下文调用它,则会生成编译时错误。 最佳答案 没有办法告诉编译器只应从catch处理程序调用特定函数

c++ - 想要 : a C++ template idea to catch an issue, 但在编译时?

我们有一个常量结构数组,像这样:staticconstSettingsSuT_table[]={{5,1},{1,2},{1,1},etc};结构如下:size_bytes:num_items:其他“元数据”成员所以“总大小”是单个元素的size_bytes*num_items。所有这些信息都在const数组中,在编译时可用。但是,请注意,_table的总大小与EEPROM本身的大小无关。_table不镜像EEPROM,它只描述了布局、用途和我们需要的其他“元数据”类型的信息。但是,您可以使用此元数据来确定我们正在使用的EEPROM的数量。数组简单地描述了存储在外部EEPROM中的数据