草庐IT

protected_class_method

全部标签

c++ - 使用 googletest 测试 protected 成员

我对谷歌测试时的继承感到困惑。我有一个具有protected属性的A类。如果我想访问那些我必须扩展那个类,但同时我还需要扩展public::testing::Test用于gtest的唯一目的.这个问题最优雅的解决方案是什么?我也试图避免#defineprotectedpublic 最佳答案 为避免在被测类中留下测试痕迹,请使用夹具的多重继承:classToBeTested{protected:boolSensitiveInternal(intp1,intp2);//Stillneedstesting}//Google-test:cl

c++ - 错误 C2248 : 'std::basic_ios<_Elem,_Traits>::basic_ios' : cannot access private member declared in class 'std::basic_ios<_Elem,_Traits>'

我无法理解这个错误。这个错误不在我正在调试的类中。(是吗?)错误是:c:\programfiles\microsoftvisualstudio10.0\vc\include\fstream(890):errorC2248:'std::basic_ios::basic_ios':cannotaccessprivatememberdeclaredinclass'std::basic_ios'1>with1>[1>_Elem=char,1>_Traits=std::char_traits1>]1>c:\programfiles\microsoftvisualstudio10.0\vc\inc

c++ - 调用子覆盖时始终调用父类(super class)虚函数

我有这样的结构:classA{public:virtualvoidfunc(inta){cout现在,在95%的情况下,当我从A继承时,我会覆盖func,在100%的情况下,我应该在执行任何其他操作之前调用A::func();?我怎样才能防止手动编写这个。有时我什至忘记在子类中调用A::func();并得到运行时错误、抛出等。 最佳答案 NVIpattern怎么样??classA{public:voidfunc(inta){cout 关于c++-调用子覆盖时始终调用父类(supercla

将实例方法作为callback in Class Initializer中的回调

考虑以下代码:classBar{letcallback:()->()init(callback:@escaping()->()){self.callback=callback}funcevent(){self.callback()}}classFoo{letbar:Barinit(){self.bar=Bar(callback:self.handler)}funchandler(){print("Handled")}}基本想法是我们想要每个Foo有一个Bar,当event()被称为Foo'bar,将会通知Foo的处理程序方法。但是,上面的设置警告Foo自初始化,因为我们正在使用self在初始化

c++ - 如何处理失败的方法 : by using exceptions or making the methods return bool?

如何处理失败的方法:使用异常使方法返回bool值第一种方法是当出现问题时抛出异常。但是有问题的代码需要放在tryblock中,然后你需要编写catchblock。您需要检查返回值的第二种方法方法,然后做一些事情。那么基本上不是同一个机制吗?你有两个部分:检测到出现问题然后采取措施。那么我使用哪种方法重要吗? 最佳答案 异常的主要好处是它们是非本地的。您可以在抛出异常的地方捕获几个调用层之外的异常。这样,介于两者之间的代码就不必关心异常(除了确保在展开期间进行适当的清理,即异常安全),这使得异常情况不太可能被遗忘。但这种好处是有代价的

c++ - 如何防止派生类公开私有(private)/ protected 虚函数?

将所有虚函数构造为私有(private)或protected基类接口(interface)是有充分理由的(参见this)。但是,如何防止派生类(可能在外部客户手中)将私有(private)虚函数设为公共(public)呢?在VirtuallyYours,作者讨论了这个问题,但没有讨论解决方案。编辑:根据您的回答和我之前的想法,似乎没有办法阻止这种情况。但由于在这种情况下,很容易出错(客户端肯定会触及protected虚函数),编译器对这种用法发出警告是有道理的。我试着用g++测试它。首先,我写道:classA{protected:virtualvoidnone(){return;}};

c++ - Qt Creator "override method"快捷方式?

QtCreator有没有像eclipse一样的“覆盖方法”快捷方式?对于那些不了解Eclipse的人,有一个显示对话框的上下文菜单“Source>OverrideMethod”。检查您要覆盖的方法,它将为这些方法生成stub。 最佳答案 右键单击类名从上下文菜单中选择Refactor->InsertVirtualFunctionsofBaseClasses顺便说一句,我使用的是QtCreator3.4.1。 关于c++-QtCreator"overridemethod"快捷方式?,我们在

c++ - Superclass::method 或 this-> 方法之间的区别

如何以及何时调用父类(superclass)方法?两个选项请引用代码段:classSuperClass{public:voidmethod();};classSubClass:publicSuperClass{public:voidsomeOtherMethdo(){this->method();SuperClass::method();}}; 最佳答案 使用this->method()调用一个函数,该函数要么在您的父类(superclass)中实现,要么由您自己的类实现。当使用superClass::method()时,您一定要调

c++ - 错误 : redefinition of class

这是我的代码://inmain.cpp#include"iostream"#include"circle.cpp"#include"rectangle.cpp"#include"shape.cpp"usingnamespacestd;intmain(){Shapeshapes[10];for(inti=0;iwidth=width;}virtualvoidsetHeigth(intheight){this->height=height;}};//inshape.cppclassShape{public:virtualintgetArea()const=0;};编译时,我得到这个错误:e

c++ - 为我的类(class)重载流运算符 << >> 的正确方法是什么?

我对如何在C++中为我的类重载流运算符感到有点困惑,因为它们似乎是流类上的函数,而不是我的类上的函数。这样做的正常方法是什么?目前,对于“getfrom”运算符,我有一个定义istream&operator>>(istream&is,Thing&thing){//etc...哪个有效。Thing类的定义中没有提到它。我希望它能够在其实现中访问我的Thing类的成员-我该怎么做? 最佳答案 您的实现没有问题。您需要执行的唯一额外步骤是在Thing中将您的运算符(operator)声明为friend:classThing{public: