草庐IT

user_back_end_friends

全部标签

c++ - 为什么 push_back 在包含 unique_ptr 的结构上成功,除非该结构具有自定义析构函数?

当且仅当我删除Foo的自定义析构函数时,以下代码才能编译。structFoo{std::unique_ptrbar;~Foo(void){}//ThisLine};std::vectorfoos;foos.push_back(Foo());以下是我认为我对这种情况的理解:失败是因为unique_ptrs无法复制,std::vector::push_back(thing)调用thing's复制构造函数。如果我写Foo显式移动bar的自定义复制构造函数,那么一切都会好起来的。但是,禁用ThisLine将导致代码编译。我认为即使没有ThisLine也应该编译失败,因为我仍在尝试push_ba

c++ - 如何解决 "class must be used when declaring a friend"错误?

classtwo;classone{inta;public:one(){a=8;}friendtwo;};classtwo{public:two(){}two(onei){cout我从Dev-C++收到此错误:aclass-keymustbeusedwhendeclaringafriend但是用MicrosoftVisualC++编译器编译时它运行良好。 最佳答案 你需要friendclasstwo;代替friendtwo;此外,您不需要单独转发声明您的类,因为友元声明本身就是一个声明。你甚至可以这样做://noforward-de

c++ - 为什么我不能将 std::begin/std::end 与 int(*p)[3] 一起使用,而我可以与 int(&p)[3] 一起使用?

这个有效:voidfoo(int(&a)[3]){autoibegin=begin(a);autoebegin=end(a);}虽然这不是:voidfoo(int(*a)[3]){autoibegin=begin(a);autoebegin=end(a);}我认为int(&a)[3]和int(*a)[3]是同一个意思! 最佳答案 您的代码类似于:voidfoo(vector&a){autoibegin=begin(a);autoebegin=end(a);}voidfoo(vector*a){autoibegin=begin(a);

c++ - 对 pop_back() 感到困惑,C++

我试图理解vector::pop_back()的行为。所以我有以下代码片段:vectortest;test.push_back(1);test.pop_back();cout也许它是对的,但令我惊讶的是它打印出1。所以我很困惑。pop_back()是否只能删除具有index>0的元素?提前致谢! 最佳答案 您通过在空vector上调用front来调用未定义的行为。这就像超出数组边界的索引。任何事情都可能发生,包括返回1。 关于c++-对pop_back()感到困惑,C++,我们在Stac

c++ - 与模板特化成为 friend 时可能出现 gcc 错误

在回答关于SO的另一个问题时,我遇到了一个有点可疑的gcc编译器错误。有问题的片段是templateclassA;templatevoidoperator*(A,A);templateclassA{friendvoid::operator*(A,A);...最后一行给出了著名的警告frienddeclaration'voidoperator*(A,A)'declaresanon-templatefunction稍后会导致硬错误。完整代码可见here.现在,问题是我认为这种行为不合适。[temp.friend]/1中的标准说:Forafriendfunctiondeclarationth

c++ - 来自不同命名空间的模板模板参数可以成为 friend 吗?

如果这个问题的标题没有帮助,我深表歉意;如果不给出以下示例,我不知道如何简洁地提出这个问题:templateclassArg>classC{typedefCtype;friendclassArg;public:C(){a_.set(this);}private:inti_;Arga_;};templateclassArg1{public:voidset(Type*t){t_=t;t_->i_=1;}private:Type*t_;};namespaceNS{templateclassArg2{public:voidset(Type*t){t_=t;t_->i_=2;}private:T

c++ - g++ 错误 : specialization after instantiation (template class as friend)

考虑以下C++代码:templateclassSingleton{};classConcreteSingleton:publicSingleton{templatefriendclassSingleton;};intmain(){}Singleton应该是ConcreteSingleton的friend:它适用于Microsoft的可视化C++编译器。但是,我不能用g++4.8.4编译它。错误是:error:specializationof‘Singleton’afterinstantiationtemplatefriendclassSingleton;有什么办法可以解决吗?

c++ - 私有(private)函数作为其他类的 friend

我有以下用C++编写的代码:#includeusingnamespacestd;classWindow;classLevel{intlevel;intget(Window&w);public:Level(void):level(3){}voidshow(Window&w);};voidLevel::show(Window&w){cout我想访问类Window的私有(private)成员,只能通过友元函数get访问,这也是类Level的私有(private)函数.当我尝试编译时出现错误C2248。是否可以将私有(private)函数设为其他类的友元? 最佳答案

c++ - push_back 到 vector c++ 时出现段错误

我正在尝试使用push_back方法将空白对象附加到列表。主要.cppvectorfacial_memory;printf("2\n");//Addpeoplefacememoriesbasedonnumberofsectionsfor(inti=0;i在push_back方法调用中,程序因段错误而崩溃。我环顾了类似的问题,他们指出了我在这里的解决方案。我也尝试将FacialMemory()传递到push_back调用中,但仍然是同样的问题。FacialMemory类定义如下:面部内存.hclassFacialMemory{private:vectorface_memory;publi

c++ - 访问说明符对 friend 功能重要吗?

在一个类中,如果函数在不同的说明符(如private、protected或public)中被声明为friend,那么有什么区别吗?据我了解,friend功能不是成员。因此,这应该无关紧要。但是,如果我看到static-它也不是成员,但访问说明符很重要。所以,我有点困惑。所有这些代码如何正常工作?下面的类有区别吗?/**Privatefriendfunction**/classfrienddemoFunction{private:unsignedintm_fanSpeed;unsignedintm_dutyCycle;/**Thisfunctionisnotamemberofclassf