草庐IT

try-exception

全部标签

c++ - 除了避免 'extern C' 并获得 'C++ exception' 之外,将 Lua 编译为 C++ 有什么好处?

我是Lua的新手,我想使用C++将Lua嵌入到我们的游戏项目中。我注意到的第一件事是,允许将Lua编译为C++代码,并且从文档中,我了解到这将消除环绕Luaheader的“externC”,并且错误处理将是C++异常而不是跳远/定跳。我的问题是,除了这两个区别之外,将Lua代码编译为C++代码还有其他真正的好处吗?这两个并不能真正说服我,因为,1)用'externC'包装cheader并不困扰我,2)我们的项目不允许异常,所以我必须更改luaconf.h才能使用longjump/setjump任何方式。 最佳答案 那些是将Lua编译

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

c++ - 当前形式的 `std::exception` 是多余的吗?

通常,当我想创建自己的异常时,我继承自std::exception或std::runtime_error。有什么能阻止我创建自己的空“标签类”吗?classout_of_bounds_access{};//or:classmemory_leak{};然后扔那个?毕竟,大多数情况下,是类名携带了有关出错的信息,而不是异常类的成员。好吧,所以我认为这是个坏主意,但为什么呢?为什么这是个坏主意?附言我知道在某些情况下,“定制的”异常携带信息,后者用于确定解决问题的正确方法......然而,如果你仔细想想,像这样的情况可以经常(不总是,但经常)被重新处理以抛出和捕获多个不同的标签类,而不是只有

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

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

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可能会发生虚假唤醒及其背后的基本原理。但

c++ - std::rethrow_exception 和抛出的异常类型

在一个库中,我有一个异常层次结构(RuntimeException->RecognitionException->NoViableAltException)。在执行过程中,抛出一个NoViableAltException,它被如下捕获并从中创建一个异常指针:try{//codethatthrowsNoViableAltException}catch(RecognitionException&re){std::exception_ptre=std::make_exception_ptr(re);reportError(e);}e的值在其他地方使用,与本题无关。在reportError()

c++ - main() 函数中的 try\catch block 没有括号

VisualStudio2015;C++语言。我记得我在某处读到有关入口点(即main方法)的内容,可以这样写:#includeusingnamespacestd;intmain()try{return0;//Iamhere...}catch(...){cout即在这种情况下,try\catchblock不在括号中:intmain(){//startbrackettry{return0;}catch(...){return1;}}//endbracket这两种情况都已成功编译并且也可以正常工作,但是......在第一个变体中,当我在tryblock之后逐步按下F10键时,我也进入cat

c++ - 如何获取 promise::set_exception(x) 的参数?

我在几个地方找到了关于如何使用promise的引用copy_exception,但我在当前的FDIS中找不到它。自从那些博客以来,是否有关于如何使用set_exception()的替代方法?例如herevoidasyncFun(promiseintPromise){intresult;try{//calculatetheresultintPromise.set_value(result);}catch(MyExceptione){intPromise.set_exception(std::copy_exception(e));//我发现std::current_exception()h