草庐IT

try-catch-rethrow

全部标签

c++ - 在 try catch block 中断言

我目前正在对一段代码添加处理以使其不会崩溃。目前它有每个步骤,然后是一个ASSERT语句,以确保上一步没有出错。如果这些步骤中的某个步骤出了问题,那确实是出了大问题。该程序应该停止。虽然在Release模式下程序遇到断言,但愉快地继续运行并崩溃。为了解决这个问题,我将方法包装在一个try/catchblock中,并在断言所在的位置抛出错误。这应该捕获我们跟踪的所有错误和我们没有跟踪的其他错误。现在我的问题是,我是否仍应使用断言来通知程序员这不应该发生?或者现在将它们取出,因为它不会因为catchblock(我清理对象的地方)而崩溃?或者我应该只在catchblock中抛出一个断言,而不

C++11 在不使用 try/catch block 的情况下安全地加入线程

根据文档here和here,如果joinable()==false,C++11线程的join方法将抛出std::system_error。因此,等待线程完成执行的自然方式是:if(thread2.joinable())thread2.join();但是,这有可能抛出std::system_error。考虑线程1调用thread2.joinable(),返回true,说明thread2还在运行。然后调度程序暂停线程1并将上下文切换到线程2。线程2完成,然后线程1恢复。线程1调用thread2.join(),但线程2已经完成,因此抛出std::system_error。一个可能的解决方案是

c++ - 如何使用 lock_guard 和 try_lock_for

我可以使用boost::lock_guard获取boost::mutex对象上的锁,并且此机制将确定一旦boost::lock_guard超出范围将释放锁:{boost::lock_guardlock(a_mutex);//Dothework}在这种情况下,无论代码块是否因异常退出,a_mutex都会被释放。另一方面,boost::timed_mutex也支持方法try_lock_for(period),例如if(a_timed_mutex.try_lock_for(boost::chrono::seconds(1))){//Dotheworka_timed_mutex.unlock(

c++ - 函数 try block 的目的是什么?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Whenisafunctiontryblockuseful?Differencebetweentry-catchsyntaxforfunction这段代码在UseResources类中构造Dog对象时抛出一个int异常。int异常被普通的try-catchblock捕获,代码输出:Cat()Dog()~Cat()Insidehandler#includeusingnamespacestd;classCat{public:Cat(){cout现在,如果我们将UseResources()构造函数的定义替换为使用f

c++ - 为什么 std::multimap 没有实现 try_emplace?

C++17引入了try_emplacestd::map的方法,所以现在我可以编写如下代码:structTest{Test(inti,intj){}};std::maptmap;tmap.try_emplace(10,10,10);但是没有try_emplace对于std::multimap,所以piecewise_construct仍然需要。这有技术原因吗? 最佳答案 isthereatechnicalreasonforthis?是的。try_emplace()的目的是如果键已经存在于映射中则不执行任何操作。但是对于std::{un

java - catch block 在 C++ native 库中不起作用

我正在用C++编写一个Javanative库,并在native库本身中使用异常处理,但是一旦我抛出异常,库就会崩溃。这是我的简单测试程序,当我从Java测试中调用它时,它会在抛出异常时立即崩溃。catchblock不工作。任何想法我错过了什么。谢谢。#include"Test.h"#includeJNIEXPORTvoidJNICALLJava_Test_helloWorld(JNIEnv*,jobject){std::cout编译和链接:g++-m64-fPIC-fexceptions-ctest.cppg++-shared-m64-Wl,-soname,libtest.so-Wl,

c++ - 使用 CATCH C++ 单元测试框架测试两个 std::vectors 是否相等

我是CATCH的新手,我想知道如何测试两个std::vectors是否相等。我非常天真的尝试是这样的:#defineCATCH_CONFIG_MAIN#include"catch.hpp"#includeTEST_CASE("arevectorsequal","vectors"){std::vectorvec_1={1,2,3};std::vectorvec_2={1,2,3};REQUIRE(vec_1.size()==vec_2.size());for(inti=0;i有更好的方法吗?像魔法一样的东西REQUIRE_VECTOR_EQUAL?此外,如果一个数组包含double{1.

c++ - 我如何使用 try...catch 来捕获浮点错误?

我在visualstudioexpress中使用c++生成随机表达式树,用于遗传算法类型的程序。因为它们是随机的,树经常产生:被零除、溢出、下溢以及返回“inf”和其他字符串。我可以为字符串编写处理程序,但文献让我对其他人感到困惑。如果我理解正确,我必须先设置一些标志?建议和/或指向一些文献的指针将不胜感激。编辑:double变量中返回的值为1.#INF或-1.#IND。我把它们称为字符串是错误的。 最佳答案 根据http://msdn.microsoft.com/en-us/library/aa289157%28v=vs.71%2

c++ - 如果我尝试在 C++ 中的 catch block 中抛出一些东西,为什么会导致终止

我有以下C++代码,它给了我一个惊喜。问题是,如果我在catchblock中抛出除了重新抛出之外的东西,程序将通过调用abort终止并在GCC4中给出错误消息,“在抛出'int'实例后调用终止”。如果我只使用“抛出;”重新扔进catchblock,一切都会好起来的。#include#include#includeusingnamespacestd;intmain(){try{throwstd::string("firstthrow");}catch(std::string&x){try{std::cout 最佳答案 如果你抛出一个i

c++ - std::timed_mutex::try_lock* 虚假地失败

try_lock*是指try_lock()、try_lock_for()和try_lock_until()。根据cppreference,这三种方法都可能会虚假地失败。以下引用自try_lock_for()的描述Aswithtry_lock(),thisfunctionisallowedtofailspuriouslyandreturnfalseevenifthemutexwasnotlockedbyanyotherthreadatsomepointduringtimeout_duration.我知道std::condition_variable可能会发生虚假唤醒及其背后的基本原理。但