草庐IT

cpp_exceptions_handling

全部标签

c++ - 在两个不同的头文件中声明相同的命名空间,然后将它们包含在一个 cpp 中

Holla,在QtCreator自动生成的Qt5项目文件中,在两个单独的header中声明了一个名为Ui的命名空间,并且它们都包含在一个cpp文件中//mainwindow.hnamespaceUi{classMainWindow;}//ui_mainwindow.hnamespaceUi{classMainWindow:publicUi_MainWindow{};intx;}//mainwindow.cpp#include"ui_mainwindow.h"#include"mainwindow.h"MainWindow::MainWindow(QWidget*parent):QMai

c++ - yaml-cpp 0.5.1 的可选 key

Apreviousanswer描述了如何使用YAML::Node::FindValue("parameter")检查yaml节点中是否存在键。不幸的是,我不能在最新版本(0.5.1)中调用它:error:‘classYAML::Node’hasnomembernamed‘FindValue’这是预期的工作还是有一个等效的功能可以在最新版本中工作? 最佳答案 在新的API中,您可以检查:if(node["parameter"]){//...}在if(...)block中定义一个对象可能很方便:if(YAML::Nodeparamete

c++ - 如何将消息附加到 std::exception?

我想做以下事情:std::stringfileName="file";std::ifstreamin(fileName.c_str());in.exceptions(std::istream::failbit);try{loadDataFrom(in);}catch(std::ios_base::failure&exception){std::stringlocation=std::string("infile\n")+fileName;//appendthe"location"totheerrormessage;throw;}如何将错误消息附加到异常? 最

c++ - 安置新的和异常(exception)

“placementnew”运算符声明如下:void*operatornew(std::size_tsize,void*ptr)noexcept;但是虽然它不涉及任何实际分配,因此消除了错误的分配异常,但指针仍然可能指向错误的位置,在这种情况下,人们会期望得到一个范围或溢出/下溢错误,但是它被声明为noexcept的事实不会直接终止执行吗?这是否也意味着在C++11之前放置new将抛出并尝试处理std::unexpected而不是直接处理std::set_unexpected崩溃?“以防万一”,难道不应该有大量的placementnew吗? 最佳答案

c++ - boost::exception 和 std::exception 之间的关系

假设有如下代码:try{//Dosomebooststuffhere}catch(conststd::exception&stdEx){cout问题:1)我知道代码适用于某些boost异常,即使std::exception和boost::exception不在同一个继承路径上。为什么它会起作用?2)它是否适用于所有boost异常?换句话说,是否有可以触发低于std::exception处理程序的boost::exception处理程序的示例? 最佳答案 如您所说,boost::exception不是从std::exception派生

java - JNI : How to handle the creation/removal of wrapped C++ object

我想包装一个C++对象,以便我可以从Java访问它。通过阅读jniandusingc++new'edobjectsinjava,我了解了如何在我的Java包装器类中保存对我的C++对象的引用。.不过,我还没有弄清楚的一件事是如何处理我的C++对象的创建和删除。当然,我可以引入创建和删除我的C++对象的native方法,但这意味着我必须在Java中自己处理内存管理……不是很Javaish。在我的Java包装器对象创建和垃圾收集时,是否有任何我应该实现的本地方法被调用? 最佳答案 您必须编写native方法来创建和销毁您的C++对象。关

c++ 如何正确地将 .cpp 拆分为 .cpp 和 .h

我真的不熟悉将.cpp拆分为.cpp和.h。我以前使用过.h文件,但从未真正将.cpp拆分为.cpp和.h。我知道.h文件仅用于声明,而.cpp用于定义,我试图将.cpp拆分为.cpp和.h,但出现了很多错误,所以我想知道是否有人可以帮助我编写代码。下面的类是尚未拆分为.cpp和.h的类,只是为了向大家展示“之前的版本”。TicketOrder.cpp#includeusingnamespacestd;classTicketOrder{private:chartype;intquantity;public:friendstd::ostream&operator现在,我将把上面的类拆分为

C++ - CPP 和 H 中定义的内联有什么区别

这不是一个“我有这个问题”的问题,而是一个“我真的很想了解该语言如何更好地工作”的问题。我最近开始遇到在给定类的.cpp文件中定义内联功能。我想了解内联功能的定义点之间的区别实际上是什么。在对CPP中定义的内联进行对象级分析时,似乎有更高百分比的C++中声明的内联(与在.h中定义的相反)被优化为映射函数而不是合法内联-是这是主要区别,或者这背后是否还有其他我没有看到的目的。 最佳答案 没有区别。inline是对编译器的提示,但现在并不是特别重要,因为编译器非常擅长在没有您帮助的情况下确定是否内联扩展函数(参见register关键字)

C++/QML : How to define and handle multiple contexts for dynamically created components?

基本上我的情况是这样的:我有一个扩展QQuickView的类,它通过设置上下文属性将某些对象从C++公开到QML。显示的View是从QML创建的,并且都是同一定制组件的不同实例;当某些事件发生时会创建新View,当这种情况发生时,现有View应显示最初在C++端分配给它们的对象,而新View应显示分配给它们的对象。所以,在C++方面,我有这样的东西:WindowManager::WindowManager(QQuickView*parent):QQuickView(parent){//Settingthesourcefiletousethis->setSource(QUrl("qrc:

c++ - std::current_exception 是否应该从类的析构函数中的 catch block 返回非空

我和我的同事认为我们在VisualC++2012和2013中发现了一个错误,但我们不确定。以下代码中对std::current_exception的调用是否应该返回一个非空的exception_ptr?似乎在我们尝试过的大多数其他编译器上:#include#include#includeclassA{public:~A(){try{throwstd::runtime_error("ohno");}catch(std::exception&){std::clog在VisualC++下运行时,我们得到“0”(假,这意味着返回的exception_ptr为空)。其他编译器,例如g++,打印“