草庐IT

lldb_private

全部标签

c++ - LLDB 有时显示 vector 数据,有时不显示

在调试的大多数情况下,如果我有一个vector(在Xcode9中),我会看到一个索引列表,代表vector中的值。需要其他时候,我得到这种无用的表示:不受欢迎我无法弄清楚是什么条件导致LLDB以不希望的方式显示vector。问题是什么导致了不良行为?是否可以在不重写代码的情况下修复它?这是LLDB中的错误吗?这是一个重现不良行为的简短代码示例:#include#includestd::vectorcreateVector(){std::vectorv={1,2,3};returnv;}intmain(intargc,constchar*argv[]){constauto&v=creat

c++ - 将其中一个继承的 protected 成员设为私有(private)

classA{protected:intm_a;intm_b;};classB:publicA{};在B类中,我想将m_a设为私有(private)。下面的做法是否正确classB:publicA{private:intm_a;};这不会产生2个m_a拷贝吗? 最佳答案 调整成员访问控制的正确方法是使用usingdeclaration:classB:publicA{private:usingA::m_a;}只写intm_a;确实会导致m_a的两个拷贝,并且派生类将能够访问A的通过编写A::m_a复制m_a。

c++ - 在 C++ 中,我们如何在不使用友元函数的情况下通过对象调用私有(private)函数?

我看到这段用C++编写的代码:#includeusingnamespacestd;classBase{public:virtualintfun(inti){coutfun(10);return0;}输出:Derived::fun(intx)called在以下情况下:#includeusingnamespacestd;classBase{public:virtualintfun(inti){}};classDerived:publicBase{private:intfun(intx){}};intmain(){Derivedd;d.fun(1);return0;}输出:编译器错误。谁能解

c++ - 继承和复制构造函数——如何从基类初始化私有(private)字段?

我有2个类,A和B。在A中,我有3个私有(private)字段。在B类中,我想编写一个复制构造函数,并从A类中初始化私有(private)字段。但是,这不起作用:#include#includeusingnamespacestd;classA{private:string*field1;string*field2;string*field3;doublenum1;public:A(string*o,string*n,string*m,doublea=0){field1=newstring(*o);field2=newstring(*n);field3=newstring(*m);num

c++ - 这段代码如何创建一个只有私有(private)构造函数的类的实例?

我正在开发一个声音库(使用OpenAL),并从FMOD提供的界面中获得灵感,您可以看到界面atthislink.我提供了一些概念,例如:Sound、Channel和ChannelGroup,正如您通过FMOD接口(interface)看到的那样,所有这些类都有一个私有(private)构造函数,例如,如果您要创建一个Sound,您必须使用函数createSound()由System类提供(与创建Channel或ChannelGroup相同)。我想提供一个类似的机制,但我不明白它背后是如何工作的。例如,createSound()函数如何创建新的Sound实例?构造函数是私有(privat

c++ - openMP - 与 for 循环和私有(private)并行化

我编写了一个函数来评估集合(set_)中的点处的给定函数。没有并行化的代码是这样的:voidMethod::evaluateSet(double*funcEvals_,double**set_){for(intj=0;j这一切正常。然后我使用openMP进行并行化,使用并行构造,并为每个线程提供变量set_的私有(private)拷贝。循环是#pragmaompparallelforprivate(set_)for(intj=0;j它崩溃,并且在if评估时发生错误,set_isbeingusedwithoutbeeninitialized。我不明白。由于我将set_变量设置为私有(pr

c++ - Cpp 中的私有(private)静态数据成员.. 只能在其定义时初始化,而类内初始化无效?

在头文件中初始化我得到以下错误:invalidin-classinitializationofstaticdatamemberofnon-integraltype'bool[8]'如果我尝试在.cpp中初始化,我得到:'boolIon::KeyboardInput::key[8]'isastaticdatamember;itcanonlybeinitializedatitsdefinition标题如下:enumMYKEYS{KEY_UP,KEY_DOWN,KEY_LEFT,KEY_RIGHT,KEY_W,KEY_S,KEY_A,KEY_D};classKeyboardInput{pub

c++ - 私有(private)子句中的变量与 OpenMP 中并行区域中定义的变量之间有什么区别吗?

我想知道是否有任何理由更喜欢OpenMP中的private(var)子句而不是(私有(private))变量的本地定义,即intvar;#pragmaompparallelprivate(var){...}对比#pragmaompparallel{intvar;...}此外,我想知道私有(private)子句的意义何在。OpenMP:arelocalvariablesautomaticallyprivate?部分解释了这个问题,但我不喜欢这个答案,因为即使C89也不禁止您在函数中间定义变量,只要它们在作用域的开头(当您进入并行区域时会自动出现这种情况)。因此,即使对于老派的C程序员来说

c++ - 如何访问其他模板类实例的私有(private)成员?

这个问题在这里已经有了答案:HowtoshareprotectedmembersbetweenC++templateclasses?(1个回答)关闭8年前。这个极小的示例将无法编译,因为A无法访问私有(private)成员i在AtemplateclassA{inti;public:templatevoidcopy_i_from(constA&a){i=a.i;}};intmain(void){Aai;Aad;ai.copy_i_from(ad);return0;}我找不到使这些模板实例成为friend的正确方法。

c++ - 访问从成员函数返回的私有(private)嵌套类

请帮助我理解为什么类成员函数可以返回私有(private)嵌套类对象,以及为什么可以在该私有(private)嵌套类上调用成员函数,例如:classY{classX{public:voidf(){cout我用GCC和VisualC++进行了测试,最后一行在两者上都进行了编译。我似乎无法在C++标准中找到任何使它有效的内容。知道为什么会这样吗?编辑:另一个观察:voidi(){Yy;Y::Xx2=y.g();//Error:classY::Xisprivatex2.f();//Errorautox3=y.g();//OKx3.f();//OK} 最佳答案