它是否允许编译器内联它,知道只有同一个类中的函数才能访问它?还是只是为了程序员的方便? 最佳答案 编译器可以(但不是必须)按照您的建议进行优化,但这不是要点。访问修饰符的目的是在编译时捕获某些类(没有双关语)的编程错误。私有(private)函数是这样的函数,如果有人从类外部调用它们,那将是一个错误,您希望尽早了解它。(任何时候你问“编译器是否可以根据可用的信息进行优化”这个问题,答案都是“是的,除非标准中有特定的规则说不允许”(例如volatile的规则,其全部目的是抑制优化)。然而,编译器不一定打扰根据任何给定的信息进行优化。毕
我有一个类,该类的部分输入是一个可变长度的vector(称为数据)(假设它的长度为N)。我在函数之后包含了这个:N=data_->size();在类的私有(private)部分,我想声明一个数组doubleA[N][N];.但是,当我尝试这样做时,我会听到一些话error:"Nisnotatypename,static,orenumerator".如何创建数组A[N][N]?抱歉,如果这已经在其他地方解释过,因为我是c++的新手,所以甚至不知道要寻找什么!编辑——附加代码:classfoo{public:foo(std::vector&data):data(data_){N=data_
抱歉标题又长又乱。我有一个这样的类头文件#pragmaonce#include#include#includeclassA{public:A();Method1();Method2();private:std::threadthread;boost::asio::socketsocket;another3dpartylib::doodadgizmo;}现在类的用户不会也不应该关心私有(private)部分。我怎样才能允许用户在不拖动的情况下包含类,和?从技术上讲,用户唯一应该关心的是sizeof(A).我错了吗? 最佳答案 C++中
考虑以下代码:structCalc{Calc(constArg1&arg1,constArg2&arg2,/**/constArgN&argn):arg1(arg1),arg2(arg2),/**/argn(argn),coef1(get_coef1()),coef2(get_coef2()){}intCalc1();intCalc2();intCalc3();private:constArg1&arg1;constArg2&arg2;//...constArgN&argn;constintcoef1;//Iwanttouseconstbecauseconstintcoef2;//no
我认为这是不可能的,但我不妨问一下。我可以声明私有(private)Copy-Constructor并仍然使用默认实现吗?背景:我有一个包含非常大vector的类,除了一个成员函数外,我不想调用复制构造函数。使用标准的公共(public)复制器可能很容易导致错误,例如忘记迭代中的引用(foreach(Typeel,vectOfBigObjects)而不是foreach(Typeconst&el,vectOfBigObjects))。因此,我想保留标准的复制构造函数,但只是将其设为私有(private)。这是否可以在不重写copy-ctors定义的情况下实现?
在Qt项目中编译一组文件时,我看到了很多与此类似的警告。Infileincludedfrom/usr/local/Trolltech/Qt-4.8.6/include/QtGui/qevent.h:52:/usr/local/Trolltech/Qt-4.8.6/include/QtGui/qmime.h:119:10:warning:privatefield'type'isnotused[-Wunused-private-field]chartype;^根据各种搜索的建议,我确实添加了条目QMAKE_CXXFLAGS+=-Wno-unused-private-field到.pro文件
我们的代码中有一个类,比如类C.我想创建一个C类对象的vector.但是,复制构造函数和赋值运算符都被特意声明为private。.我不想(也许不允许)改变它。是否有任何其他干净的方法来使用/定义vector? 最佳答案 你可以使用vector或vector>相反。 关于具有私有(private)复制构造函数的类的C++STLvector?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questio
假设我们有两个类:classBase{private:intx;public:voidf();};classFoo{//somevariablesandmethods};现在每个人都可以调用Base::f(),但我只希望Foo能够调用。为了达到这个效果,我们可以将Base::f()设为私有(private),并将Foo声明为友元:classBase{private:intx;voidf();friendFoo;};这种方法的问题在于Foo可以访问Base::f()和Base::x(并且甚至是Base的任何其他私有(private)成员)。但我希望Foo只能访问Base::f()。有没有
考虑这种情况。我正在编写一个库并希望将我的数据包装在一个命名空间中。例如://header.h#pragmaoncenamespacewrapper{//someinterfacefunctionshere..}我想将我的命名空间设为私有(private)。这样就没有人可以在里面写任何东西。例如,我们总是可以这样写。namespacestd{//somedatahere..}所以我想防止最后一种情况。除了使用包装在类中的静态函数之外,还有什么技术可以做到这一点吗? 最佳答案 不,没有。命名空间总是可以被添加到,除非它是一个匿名命名空
我肯定遗漏了关于emplace()和friend的其中一个优点。这是一个完整的最小示例,它重现了g++4.9.3的问题:classFoo{public:classBar{private:friendclassFoo;Bar(Foo&foo):foo(foo){}Foo&foo;};Bar&getBar(){//bars.push_back(*this);//worksfinebars.emplace_back(*this);//Foo::Bar::Bar(Foo&)isprivatereturnbars.back();}private:std::vectorbars;};