草庐IT

c++ - 我需要类似 "using Base::*;"的东西

如果我的基类有一个函数func(int)而我的派生类有一个函数func(double),派生的func(double)隐藏base::func(int)。我可以使用using将基础版本引入派生的重载列表中:structbase{voidfunc(int);};structderived:base{usingbase::func;voidfunc(double);}好的,很好。但是,如果我不确定base是否有func()怎么办?也就是说,因为我正在进行模板元编程,所以我实际上并不确定base是什么,但我想将它的功能提升到相同的水平——如果它们存在的话。即把上面的例子改成:structba

c++ - 从模板类 Base<A> 派生类 A 以便 Base<A> 可以使用 A::B?

templateclassBase{private:typenameT::Bc;};classA:publicBase{public:classB;};这样的事情有可能吗?VC++2013说B不是A的成员。 最佳答案 故事正如在直接针对您的问题的评论中所述,您试图完成的事情根本不可能,因为引用不完整类型是非法的(T=A在Base中).解决方法CRTP情况下的常见解决方法是使用trait表示应该在Derived中可用的成员和Base,但不打算在Base中声明/定义.尽管这并不真正等同于您要完成的目标,但它非常接近它,并且遵循某种等同的

C++:我可以在函数调用期间将 vector <derived_class> 转换为 vector <base_class> 吗?

我有一个现有的类和函数,如下所示:Classbase_class{...}voidFunc(...,vector&vec_b,...){//insidethefunction,thevectorvec_bisbeingre-organizedandre-sized}我定义了一个派生类,如下所示:Classderived_class:publicbase_class{...}现在,不改变函数Func,我可以传递一个vector吗?进入Func,例如:voidmain(){vectord;Func(...,d,...);}派生类d经历同样的重组和重新调整规模?我知道我可以在函数调用中毫无问

c++ - 从 Derived* 到 void* 到 Base* 的 static_cast

我想将指向派生类成员的指针转换为void*,然后从那里转换为基类的指针,如下例所示:#includeclassBase{public:voidfunction1(){std::cout(&d);Base*baseptr=static_cast(ptr);baseptr->function1();baseptr->function2();}这会编译并给出所需的结果(分别打印1和2),但它能保证工作吗?我在这里找到的static_cast的描述:http://en.cppreference.com/w/cpp/language/static_cast只提到转换为void*并返回到指向相同类

c++ - 将私有(private)部分保留在 c++ header 之外 : pure virtual base class vs pimpl

我最近从Java和Ruby切换回C++,令我惊讶的是,当我更改私有(private)方法的方法签名时,我不得不重新编译使用公共(public)接口(interface)的文件,因为私有(private)部分也在.h中文件。我很快想出了一个解决方案,我想这对Java程序员来说是典型的:接口(interface)(=纯虚拟基类)。例如:香蕉树.h:classBanana;classBananaTree{public:virtualBanana*getBanana(std::stringconst&name)=0;staticBananaTree*create(std::stringcons

c++ - 如何在C++中实现继承并解决错误 "parent class is not accessible base of child class"?

我是C++新手。我喜欢探索C++中继承的概念。每当我尝试编译以下代码时,我都会收到错误消息:forC++includes,orinsteadofthedeprecatedheader.Todisablethiswarninguse-Wno-deprecated.D:\CPracticeFiles\Vehicle.cpp:Infunction`intmain()':D:\CPracticeFiles\Vehicle.cpp:26:error:`voidVehicle::setStationary_state(bool)'isinaccessibleD:\CPracticeFiles\Ve

c++: vector<Base> 可以包含 Derived 类型的对象吗?

标题几乎说明了一切。基本上,这样做是否合法:classBase{//stuff}classDerived:publicBase{//morestuff}vectorfoo;Derivedbar;foo.push_back(bar);根据我看过的其他帖子,下面是可以的,但我不想在这种情况下使用指针,因为很难使其线程安全。vectorfoo;Derived*bar=newDerived;foo.push_back(bar); 最佳答案 不,Derived对象将是sliced:所有额外的成员都将被丢弃。使用std::vector>而不是原

C++ 继承 : Calling Base Class Constructor In Header

假设类Child是类Parent的派生类。在一个五文件程序中,我如何在Child.h中指定我想调用Parent的构造函数?我认为header中的以下内容不合法:Child(intParam,intParamTwo):Parent(Param);在这种情况下,Child.cpp的构造函数语法应该是什么样的? 最佳答案 在Child.h中,您只需声明:Child(intParam,intParamTwo);在Child.cpp中,您将拥有:Child::Child(intParam,intParamTwo):Parent(Param){

c++ - 为什么在异常掩码未设置为 eofbit 时 getline() 抛出 'std::ios_base::failure'?

考虑以下代码:ifstreamin;try{in.exceptions(ifstream::failbit|ifstream::badbit);in.open(pConfLocation);}catch(ifstream::failuree){throwstd::runtime_error("Can'topenconfigurationfile\n");}vectorlns;strings;in.clear();while(!in.eof()){getline(in,s);boost::algorithm::trim(s);lns.push_back(s+='\n');}所以:我根据t

c++ - Clang claims that `member reference base type ' X' is not a structure or union`,但 X 是具有推导参数的结构模板

考虑以下代码:templatestructX{X(T){}voidfoo(){}};templatestructY{intobject=0;voidbar(){X(object).foo();}};Liveongcc.godbold.orgGCC8.2编译它,而Clang7吐出以下错误::13:18:error:memberreferencebasetype'X'isnotastructureorunionX(object).foo();~~~~~~~~~^~~~这对我来说像是一个错误。条件非常具体:如果任一结构不是模板,或者object不是成员变量,或者不涉及CTAD(类模板参数推导