草庐IT

num_tries

全部标签

c++ - TRY/CATCH_ALL 与 try/catch

我使用C++有一段时间了,对普通的try/catch很熟悉。但是,我现在发现自己在Windows上,在VisualStudio中编码以进行COM开发。代码的几个部分使用了如下内容:TRY{...dostuff}CATCH_ALL(e){...issueawarning}END_CATCH_ALL;这些宏有什么意义?与内置的try/catch相比,它们有什么好处?我试过用谷歌搜索这个,但是很难搜索到“tryvsTRY”。 最佳答案 这是一个MFC宏:http://msdn.microsoft.com/en-us/library/t8d

c++ - "if constexpr"与 "try in constexpr function"警告交互

我声称thisprogram应该是合式的:它声明了S的constexpr成员函数.但是,GCC和Clang都拒绝这个程序。templatestructS{constexprintfoo(){ifconstexpr(std::is_same_v){return0;}else{try{}catch(...){}return1;}}};intmain(){Ss;returns.foo();//expect"return0"}海湾合作委员会说:error:'try'in'constexpr'functionclang说:error:statementnotallowedinconstexprf

c++ - 调试断言失败表达式 : _pFirstBlock == pHead using OpenCV and C++ trying to call SurfFeatureDetector

我在使用OpenCV的C++中有这个函数:vectortest(Matimg){intminHessian=400;SurfFeatureDetectordetector(minHessian);vectorvKeypoints;detector.detect(img,vKeypoints);returnvKeypoints;}当我在主方法中调用此函数时,一切正常。intmain(int,char**argv){//pathtoaimage-filechar*input="image.jpg";//readimageintoMatimgMatimg=imread(input,CV_LO

c++ - 将 VC++ 的 __try/__except EXCEPTION_STACK_OVERFLOW 移植到 MinGW

我正在尝试使用VC++的try-except语句将一些代码移植到MinGW:boolsuccess=true;__try{//...}__except((EXCEPTION_STACK_OVERFLOW==GetExceptionCode())?EXCEPTION_EXECUTE_HANDLER:EXCEPTION_CONTINUE_SEARCH){success=false;_resetstkoflw();}returnsuccess;是否可以使用MinGWg++编写捕获堆栈溢出异常的代码? 最佳答案 您需要手动调用注册异常处理的

c++ - 是什么导致这种在 try block 展开期间抛出析构函数的奇怪行为?

当tryblock遇到异常时,堆栈将展开。如果在tryblock中创建了一个对象,则调用析构函数。如果析构函数抛出另一个异常,则不会捕获此异常并终止程序。如果你有:structA{~A()noexcept(false){std::cout然后你的try-catchblock是这样的:try{Aa1;Aa2;}catch(...){}然后当tryblock结束时,a2的析构函数抛出异常,异常被捕获,然后a1的析构函数抛出并终止程序。一切都按预期进行。但是,如果您引入另一个结构,该结构也抛出析构函数,但继承自A或具有A的实例作为成员,事情就会变得困惑。例如,如果您有:structB:A{~

kotlin - 我自己对 Kotlin 的 try-with-resources 缺席的解决方案

Kotlin为Closeable对象提供了use函数,但似乎他们忘记考虑AutoCloseable(例如DB准备语句)进行尝试-with-resources完全等同于Java。我已经实现了下一个“自制”解决方案:inlinefuntrywr(closeable:T,block:(T)->R):R{try{returnblock(closeable);}finally{closeable.close()}}那你就可以用下一种方式了:funcountEvents(sc:EventSearchCriteria?):Long{returntrywr(connection.prepareStat

kotlin - 我自己对 Kotlin 的 try-with-resources 缺席的解决方案

Kotlin为Closeable对象提供了use函数,但似乎他们忘记考虑AutoCloseable(例如DB准备语句)进行尝试-with-resources完全等同于Java。我已经实现了下一个“自制”解决方案:inlinefuntrywr(closeable:T,block:(T)->R):R{try{returnblock(closeable);}finally{closeable.close()}}那你就可以用下一种方式了:funcountEvents(sc:EventSearchCriteria?):Long{returntrywr(connection.prepareStat

c++ - 为什么 num_get 和 num_put 是不对称的?

std::basic_istream的算术提取运算符有non-virtualoverloadsforall8integertypes(不列出字符,它们的处理方式不同),它调用num_get::get,它有个人virtualoverloadsfor6ofthem(缺少short和int的签名版本)std::basic_ostream的算术插入运算符也有non-virtualoverloadsforall8integertypes,它调用num_put::put,它只有virtualoverloadsfor4types,它们是long、longlong及其无符号变体。对于较小的类型,插入运

c++ - 使用 try-Catch 异常处理程序和 if else 条件检查之间的区别?

这个问题在这里已经有了答案:IsthereageneralconsensusintheC++communityonwhenexceptionsshouldbeused?[closed](11个答案)关闭9年前。我在很多地方都使用过if...else语句,但是我对异常处理还是陌生的。这两者的主要区别是什么?例如:int*ptr=new(nothrow)int[1000];if(ptr==NULL){//Handleerrorcaseshere...}或try{int*myarray=newint[1000];}catch(exception&e){cout所以我们在这里使用标准异常类,它

c++ - 为什么 try...catch 需要抛出 EXACT 类型

我可以做到,没问题:longlngval=3L;inti=lngval;但如果我尝试这样做:try{throw3L;}catch(inti){cout我得到一个未处理的异常。这似乎不一致。这种情况下没有类型转换的原因是什么? 最佳答案 在第一种情况下,编译器可以准确地告诉您要做什么:将long转换为int。在第二种情况下,编译器必须假设您可能有这样的构造:try{try{throw3L;}catch(inti){/*P*/}}catch(longl){/*Q*/}这个想法是编译器永远不知道是否有一个catch(longl)潜伏在当前