草庐IT

parent_field

全部标签

c++ - 使用前向声明时如何修复 "field has incomplete type"错误

如注释中所述,此代码抛出编译器错误error:field‘fTarget’hasincompletetype。为什么会这样?我只是分配那个字段而不做任何需要知道里面是什么的操作......或者我是?也许它无法弄清楚复制构造函数?classFSRVertex;//fwdclassFSREdge{public:charfC;FSRVertexfTarget;//compilererrorFSREdge(charc,FSRVertextarget):fC(c),fTarget(target){}//compilererror};classFSRVertex{public:boost::uno

c++ - C++ 中的继承 : define variables in parent-child classes

问题我正在寻找在父子类中定义变量的最佳方法,以便通过指向其父类的指针进行调用。这是协议(protocol):classBase{public:virtualvoidfunction()=0;};classA:publicBase{public:inta,b;A(inta_,intb_):a(a_),b(b_){};voidfunction(){//dosomething..}};classB:publicBase{public:inta,b;B(inta_,intb_):a(a_),b(b_){};voidfunction(){//dosomething..}};Base*elemen

c++ - 我应该如何从 parent 的插槽中删除子对象?可能是 boost::asio 特定的

我编写了一个网络服务器类来维护一组std::网络客户端。网络客户端在断开连接时向网络服务器发出信号(通过boost::bind)。当网络客户端断开连接时,客户端实例需要从Set中移除并最终被删除。我认为这是一种常见的模式,但我遇到的问题可能是也可能不是ASIO特有的。我试图精简到只包含相关代码:/**NetworkServer.hpp**/classNetworkServices:privateboost::noncopyable{public:NetworkServices(void);~NetworkServices(void);private:voidrun();voidonNe

c++ - 使用模板继承调用祖 parent 构造函数

我选择使用模板化继承以避免多重继承和虚拟继承。我的目标是让各种child(4或5代或我无法控制的继承)有一个共同的函数调用,无论他们派生什么。我的解决方案是这样插入一个模板继承:templateclasscommon_call:publicBASE{public:voidfoo(){/*implementationindependentofbase*/}};classchild1:publiccommon_call{};classchild2:publiccommon_call{};这里有调用base的构造函数的问题。类base1和base2(不是我写的)有不同的构造函数,我必须在初始

c++ - Q文件对话框 : GtkDialog mapped without a transient parent

我有一个用C++中的Qt编写的程序的源代码片段,在Linux下运行,它创建一个QFileDialog来打开现有文件。如果我执行此操作,一切似乎都正常,但是当创建对话框时,我收到一条警告说“Gtk-Message:GtkDialogmappedwithoutatransientparent”。在另一个thread我发现调用此函数“gtk_window_set_transient_for()”可修复此错误。但是这个函数是GTK库的一部分但是我使用的是Qt框架。那么有什么解决方案可以解决这个错误吗?这个对话框的父级是一个QMainWindow:QStringfilename=QFileDia

C++ 销毁顺序 : Calling a field destructor before the class destructor

有没有办法在类析构函数之前调用字段析构函数?假设我有2个类Small和Big,Big包含一个Small的实例作为它的字段因此:classSmall{public:~Small(){std::cout当然,这会在小析构函数之前调用大析构函数:BigdestructorSmalldestructor我需要在Big析构函数之前调用Small析构函数,因为它会为Big析构函数执行一些必要的清理工作。我可以:显式调用small.~Small()析构函数。->但是,这会调用Small析构函数两次:一次显式调用,一次在Big析构函数执行后调用。有一个Small*作为字段并在Big析构函数中调用del

field.set()在Java中的静态类上

我正在尝试编写一些单元测试,以断言我的应用程序中适当的密码套件用于不同版本的AndroidSDK。为了嘲笑Build.VERSION.SDK_INT我正在尝试使用Field.set()称呼...我有一个看起来像这样的实用方法(从https://stackoverflow.com/a/40303593/1226095和链接的答案):privatestaticvoidmockSdkVersion(Fieldfield,ObjectnewValue)throwsException{field.setAccessible(true);FieldmodifiersField=Field.class.ge

C++ : sharing fields between class and superclasses

我对类和父类(superclass)共享字段有点困惑。我期待这没问题:classSuperC{public:SuperC();protected:doublevalue;};classC:publicSuperC{public:C(doublevalue);};SuperC::SuperC(){}C::C(doublevalue):SuperC(),value(value){}但编译器告诉我C没有字段“值”。C没有继承自SuperC中定义的那个?非常感谢 最佳答案 可以,但是您只能使用构造函数初始化列表语法来初始化当前类成员。您必须

c++ - parent_path() 带或不带斜杠

如documentation中所述,以下的预期输出是:boost::filesystem::pathfilePath1="/home/user/";cout问题是,你如何处理这个问题?也就是说,如果我接受一个路径作为参数,我不希望用户关心它是否应该有尾部斜线。看起来最简单的做法是在尾部附加一个斜杠,然后调用parent_path()两次以获得我想要的“/home”的父路径:boost::filesystem::pathfilePath1="/home/user/";filePath1/="/";cout但这看起来很荒谬。有没有更好的方法在框架内处理这个问题?

C++11 统一初始化 : Field initializer is not constant

我正在尝试像这样实例化一组字符串:classPOI{public:...staticconststd::setTYPES{"restaurant","education","financial","health","culture","other"};...}现在,当我这样做时,我得到了这些错误(全部在这一行):error:fieldinitializerisnotconstantstaticconststd::setTYPES{"restaurant","education","financial","health","culture","other"};error:in-class