草庐IT

exception_class

全部标签

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派生

c++ - SFINAE 专业类(class)

我想编写一个模板类,它使用SFINAE检查特征。正如我在那篇文章中读到的那样,类不能被“重载”:templateoverloadingandSFINAEworkingonlywithfunctionsbutnotclasses我写了下面的代码:classAA{public:usingTRAIT=int;};classBB{public:usingTRAIT=float;};templateclassX;templateclassX::value,int>::type>{public:X(){std::coutclassX::value,unsignedint>::type>{publi

c# - 父类(super class)构造函数中的虚拟化

我认为根据OOP的设计,虚拟化在父类(superclass)构造函数中不起作用。例如,考虑以下C#代码。usingSystem;namespaceProblem{publicclassBaseClass{publicBaseClass(){Console.WriteLine("Hello,World!");this.PrintRandom();}publicvirtualvoidPrintRandom(){Console.WriteLine("0");}}publicclassDescendent:BaseClass{privateRandomrandomValue;publicDes

c++ - "virtual base class in the case of multilevel inheritance"有意义吗

考虑以下显示多级继承的示例代码:案例1:这里类derived1是通过虚拟继承从类base派生的,类derived2是从类派生的直接类derived1。classbase{};classderived1:virtualpublicbase{};classderived2:publicderived1{};Case2:与Case1相同,只是不涉及虚拟继承classbase{};classderived1:publicbase//novirtualinheritance{};classderived2:publicderived1{};假设我在这两种情况下都创建了derived2类的对象。C

c++ - 对父类(super class)的引用

我想结合智能指针使用访问者模式,但编译器似乎无法检测子类并匹配适当的函数。我写了一个SSCE来说明问题:测试.hpp:classVisitor;classArea{public:virtualvoidvisit(constVisitor&visitor)=0;};classArea1:publicArea{public:virtualvoidvisit(constVisitor&visitor);};classArea2:publicArea{public:virtualvoidvisit(constVisitor&visitor);};classVisitor{public:virt

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++,打印“

c++ - SFINAE 优雅地检查 "template template class"(在模板参数中)

如何在模板参数中检查模板模板类的类型?例子B和C是模板类。我想创建一个类D那可以是D或D.只有D有D::f().这是我的解决方法(demo)。它有效。#includeusingnamespacestd;classDummy{};templateclassB{};templateclassC{};templateclassBC>classD{//f()isinstantiatedonlyif"BC"=="B"public:template>statictypenamestd::enable_if>::value,void>::typef(){}//^#1};intmain(){D::f(

c++ - boost 测试 : catch user defined exceptions

如果我的代码中有用户定义的异常,我将无法进行Boost测试将它们视为失败。例如,BOOST_AUTO_TEST_CASE_EXPECTED_FAILURES(MyTest,1)BOOST_AUTO_TEST_CASE(MyTest){//codewhichthrowsuserdefinedexception,notderivedfromstd::exception.}我收到一条通用消息:Caughtexception:....unknownlocation(0):....它不会将此错误识别为失败,因为它不是std::exception。所以它不遵守expected_failures条款

C++ 从父类(super class)调用子类方法

我有以下风格的代码:classSubClass;classSuperClass;classSuperClass{private:voidbar(){SubClass().foo();}};classSubClass:SuperClass{public:voidfoo(){};};所以基本上我有一个父类(superclass),我想从中调用子类的方法foo()。VS2012给我以下错误:错误1​​errorC2514:'SubClass':类没有构造函数。错误2errorC2228:'.foo'的左侧必须有类/结构/union。我想做的事情的正确结构是什么?

c++ - 将 QUrl 传递给 QNetworkRequest 构造函数会导致 "non-class type"编译器错误

当我将QUrl传递给QNetworkRequest构造函数时,我从编译器中得到了奇怪的错误。更奇怪的是它只发生在特定的情况下,举个例子:#include#includeintmain(intargc,char*argv[]){QCoreApplicationa(argc,argv);QStringstr;QNetworkRequestreq(QUrl(str));req.setUrl(QUrl(str));//error:requestformember'setUrl'in'req',whichisofnon-classtype'QNetworkRequest()(QUrl)'QNet