草庐IT

Catch-All

全部标签

c++ - std::tr1::shared_ptr 是否会抛出 bad_alloc 并且在 try/catch block 中是个好主意?

我实际上正在制作一个简单的C++SFML游戏,我想学习更多关于C++编程的知识。现在我正在使用shared_ptr来管理资源。创建新资源时,我对shared_ptrs有一些疑问,例如:shared_ptrresource(newResource(World::LEVEL));根据boostshared_ptr(Y*p)throwsbad_alloc。我不知道std::tr1是否也这样做。而且我不知道我是否应该担心将shared_ptr放入try/catchblock中以检查是否抛出bad_alloc。这是一个好的编程习惯吗? 最佳答案

c++ - catch(...) 与 catch(CException *) 之间有什么区别?

CException是VC++抛出的所有异常的基类型,所以它应该捕获所有的异常吧? 最佳答案 CException不是所有扩展的基类型(它可能是MFC代码使用的所有异常的基类型,但仅此而已)。在C++中,你可以抛出任何东西;它不必是“异常”子类,甚至不必是对象。例如写throw42;是完全合法的或thrownewstd::vector();区别很明显:catch(CException)将只捕获抛出的CException实例及其子类,而另一个会捕获任何东西。 关于c++-catch(...

c - 在 C 中尝试 catch 语句

我今天在想其他语言中存在的try/catchblock。用谷歌搜索了一段时间,但没有结果。据我所知,C中没有try/catch这样的东西。但是,有没有办法“模拟”它们?当然,有assert和其他技巧,但没有像try/catch那样也能捕获引发的异常。谢谢 最佳答案 C本身不支持异常,但您可以使用setjmp和longjmp调用在一定程度上模拟它们。staticjmp_bufs_jumpBuffer;voidExample(){if(setjmp(s_jumpBuffer)){//Thelongjmpwasexecutedandret

c++ - 我可以写一个类似于缩写函数模板的 catch 子句吗?

在我的程序的顶部,我有一个异常处理程序。它看起来像这样:try{//majorityofprogram}catch(...){Handle_All_Exceptions();}voidHandle_All_Exceptions(){try{throw;}catch(TypeAconst&e){Handle(e);}catch(TypeBconst&e){Handle(e);}catch(TypeCconst&e){Handle(e);}catch(TypeDconst&e){Handle(e);}catch(...){Handle_Unknown();}}voidHandle(Type

c++ - OpenCV ANDROID_ABI : not all variants are displayed

我从GitHub下载了OpenCV2.4.13版本.然后我使用CMake-gui为android配置了CMake项目。有一个名为ANDROID_ABI的变量,我可以使用下拉列表为其选择值。但在此列表中,我只能选择armeabi、带VFP的armeabi-v6、armeabi-v7a、带NEON的armeabi-v7a、带VFPV3的armeabi-v7a。我可以使用CMake控制台为arm64配置和生成项目,或者我可以修改cmake脚本并手动列出它。但是,当我尝试构建生成的项目时,出现错误unknowntypename'__uint128_t'__uint128_t。所以我认为我无法从

c++ - Try-catch 在共享库中不起作用?

(这类似于myotherquestion但这是另一回事,即使它是相关的)我的项目中遇到了一个大问题。我有一个处理XML并可以抛出异常的库。并且,使用它来创建配置文件类显示了我的第一个错误:库中根本没有处理异常,每个异常都没有处理。在我写的库中:try{throwstd::exception();}catch(...){printf("caught\n");}但是,异常没有被处理并立即调用std::terminate:terminatecalledafterthrowinganinstanceof'std::exception'what():std::exception编译标志是最简单的

c++ - 在现代 C++ 中使用 try..catch block 通过模板元编程包装任意函数调用

我想创建一些模板,基本上应该包装它的参数。参数应该是一个任意的函数调用,它通过一些带有前缀和后缀代码的模板元编程魔法被包装。我想像下面这样使用它:autoresult=try_call(some_vector.at(13));和try_call将以某种方式定义,它将try..catchblock包装在some_vector.at(13)周围。像这样:template//sometemplatemetaprogrammingmagicheretry{autovalue=//executetheparameterhere,i.e.some_vector.at(13);returnstd::

c++ - 使用复制构造函数且存在虚函数时出现错误 "recursive on all control paths"

下面的错误让我很困惑。这是一小段更复杂的代码。对我来说似乎很奇怪,只有模板化构造函数和虚方法的存在才会导致错误,并且只有在复制初始化对象时才会发生错误。有人有想法吗?谢谢。classA{long*p;public:A():p(0){}templateA(Tval):p(val)//1{}operatorlong*(){returnp;}};classB{virtualvoidf()//2{}};classC:publicA,publicB{};voidmain(){Cc;main()的下一行是Aa=c;如果标记为//1和//2的行都存在,则会触发以下错误:warningC4717:'C

c++ - VS 2012 : Debugger: "Break all in 5 seconds"

当我选择文本时,我的程序使用了过多的CPU资源。我不知道为什么。通常我只是按“全部中断”来查看程序当前正在做什么。但在这种情况下,我正忙于用鼠标选择文本。有什么技巧可以延迟“全部中断”命令几秒钟吗? 最佳答案 您可以使用Sleep(5000)启动一个单独的线程;DebugBreak(); 关于c++-VS2012:Debugger:"Breakallin5seconds",我们在StackOverflow上找到一个类似的问题: https://stackove

c++ - 如何将 CMake 与 Catch2 一起使用?

来自Catch2'sexample,我试着用cmake运行这个例子,我的项目结构是这样的:/factorial+--CMakeLists.txt+--/bin+--/include|+--catch.hpp|+--fact.hpp+--/src|+--CMakeLists.txt|+--fact.cpp+--/test+--CMakeLists.txt+--test_fact.cppfact.cpp:unsignedintfactorial(unsignedintnumber){returnnumberfact.hpp:#ifndefFACT_H#defineFACT_Hunsigne