草庐IT

c++ - 派生对象的 boost 序列化不调用派生的序列化()

我已经阅读了大量类似的问题,但没有找到答案。我正在使用VisualStudio2010和boost1.47。这是完整的可编译代码:#include"stdafx.h"#include#include#include#include#includeusingnamespacestd;classBaseObject{public:BaseObject(void){};virtual~BaseObject(void){};templatevoidserialize(Archive&ar,constunsignedintversion){/*nothinghappenshere*/};};cl

c++ - 将类定义传递给基类时,类定义是否完整?

我正在尝试编写一个CRTP以包含派生类型的staticconstexpr,因为这不可能只用一个类来完成。这段代码在GCC中编译得很好,但clang提示Derived是一个不完整的类型。哪个是对的?templateclassBase{public:staticconstexprTa=T(1),b=T(20);};classDerived:publicBase{public:intx;constexprDerived(intx):x(x){}}; 最佳答案 Derived在Base处不完整被实例化([class.mem]/2),这发生在

c++ - 基类和派生类的复制构造函数

我有这两个类///////////BASECLASSclassBase{public:Base(int=0);~Base();Base(Base&);Base(Derived&);////我读到如果我的派生类没有复制c'tor将调用基的复制c'tor但每次我收到从Base到非标量的转换typeDerivedrequested谁错了?我的编译器或我的书,还是我误解了?提前致谢 最佳答案 只是一个提示。下面的代码是否给出同样的错误?classbase{};classderived:publicbase{};intmain(){deriv

c++ - friend 功能在这里得到继承吗?

Derived类中的方法fun()是私有(private)的。当我们通过运行时多态调用函数ptr->fun()时,它正在执行。但这违反了派生类的封装属性。#includeusingnamespacestd;classDerived;classBase{private:virtualvoidfun(){coutfun();return0;}谁能解释一下发生了什么? 最佳答案 首先,你的Derived::fun()也是virtual,因为如果派生类中的函数与派生类中的虚函数具有相同的声明基类,派生类中的函数自动获得virtual,即使没

c++ - 如果 Derived 不向 Base 添加新成员(并且是 POD),那么可以安全地完成什么样的指针转换和取消引用?

(这是关于未定义行为(UB)的另一个问题。如果这段代码在某些编译器上“有效”,那么这在UB领域就没有任何意义。这是可以理解的。但是我们到底在下面的哪一行跨入UB?)(关于SO已经有很多非常相似的问题,例如(1)但我很好奇在取消引用指针之前可以安全地使用指针做什么。)从一个非常简单的基类开始。没有virtual方法。无继承。(也许这可以扩展到任何POD?)structBase{intfirst;doublesecond;};然后是添加(非virtual)方法但不添加任何成员的简单扩展。没有virtual继承。structDerived:publicBase{intfoo(){return

c++ - 来自私有(private) CRTP 基地的回调

以下代码不起作用,因为您不能从私有(private)基类static_cast。用C风格的转换来替换转换是可行的(尽管我最初认为这会调用未定义的行为,但显然它不会,请参阅thisanswer),但是相当丑陋,因为它还允许您绕过常量检查等.另一种方法是使CRTPBase成为友元,但这会暴露所有Derived的私有(private)成员。是否有另一种不使用C风格转换也不使CRTPBase成为友元的编写方式?templatestructCRTPBase{voidcallBase(){T*derived=static_cast(this);derived->publicMethod();}};

c++ - 实现比较运算符的模板类

将所有重载的比较运算符写入一个类是我的一项常见任务,因此我编写了一个模板类,如果派生类实现了==和=,!=.它正在工作,但具有很多转换和不那么明显的“奇怪的重复模板模式”,所以我想知道是否有更简单的解决方案?templateclassComparable{public:booloperator!=(constComparable&other){return!(static_cast(this)->operator==(*static_cast(&other)));}booloperator&other){return(static_cast(this)->operator==(*sta

c++ - 绑定(bind)到私有(private)继承的成员函数

我想将std::bind到私有(private)基类的成员函数,在派生类中使用using声明使其“公开”。直接调用函数是可行的,但绑定(bind)或使用成员函数指针似乎无法编译:#includestructBase{voidfoo(){}};structDerived:privateBase{usingBase::foo;};intmain(int,char**){Derivedd;//callmemberfunctiondirectly://compilesfined.foo();//callfunctionobjectboundtomemberfunction://nomatchi

c++ - 在具有存储基成员的基类的派生类中使用/存储派生成员

我经常遇到的情况是有一组类,Base和Derived,其中Base类拥有基类成员的所有权BaseMember,和Derived类具有指向同一对象的引用或指针,但作为DerivedMember.例如,包含具有某些特殊控制功能的某类控件的特定实例的UI面板类继承自包含通用控件并具有通用控制功能的通用类。首先说BaseMember由DerivedMemeber继承.如果不使用智能指针,我可能会这样做:classBase{protected://receiveownershipbutonlybecausewesayso,//someoneelsecanstilltrytodeleteasit'

c++ - 移动构造函数和赋值运算符 : why no default for derived classes?

为什么没有为派生类创建默认移动构造函数或赋值运算符?证明我的意思;具有此设置代码:#includestructA{A(){}A(A&&){throw0;}A&operator=(A&&){throw0;}};structB:A{};以下任一行抛出:Ax(std::move(A());Ax;x=A();但以下都没有:Bx(std::move(B());Bx;x=B();以防万一,我使用GCC4.4进行了测试。编辑:后来使用GCC4.5进行的测试显示了相同的行为。 最佳答案 通读0xFCD中的12.8(12.8/17特别是移动构造函数)