草庐IT

C++ 编译错误枚举 "does not name a type"

以下代码:foo.h#include"bar.h"classfoo{public:enummy_enum_type{ONE,TWO,THREE};foo();~foo(){}};foo.cppfoo::foo(){inti=bar::MY_DEFINE;}酒吧.h#include"foo.h"classbar{public:staticconstintMY_DEFINE=10;foo::my_enum_typevar;bar(){};~bar(){};};让g++编译器提示my_enum_type“没有命名类型”。为什么?所有header都有多个包含定义(为清楚起见,此处未显示)。谢谢

c++ - 为什么 unique_ptr<T>::~unique_ptr 需要 T 的定义?

如果我有一个“酒吧”类://bar.hclassBar{public:Bar(){}};我转发声明与另一个类“Foo”中的std::unique_ptr一起使用://foo.h#includeclassBar;classFoo{public:Foo();private:std::unique_ptrbar_;};我在Foo的实现文件中包含了它的定义://foo.cpp#include"foo.h"#include"bar.h"Foo::Foo():bar_(newBar){}我收到编译时错误“‘sizeof’对不完整类型‘Bar’的无效应用”。我从here了解到和here为了解决这个问

c++ - 如何分配/检索基类?

假设我有:classFoo{...};classBar:publicFoo{...};Foofoo;Barbar;有没有办法做到以下几点:foo_part_of_bar(bar)=foo;foo=foo_part_of_bar(bar);?谢谢! 最佳答案 假设您的意思是classBar:publicFoo,下面的代码应该可以工作。对于foo_part_of_bar(bar)=foo;*(static_cast(&bar))=foo;对于foo=foo_part_of_bar(bar);foo=bar;

c++ - 将指针 vector 转换为对象 vector

我有这个vector:std::vectorfoo;我有一个具有以下签名的函数(我无法更改它):voidbar(std::vectorconst&);如何以最少的更改将foo传递给该函数?我目前的做法是:std::vectoranother_bar(bar.size());std::transform(std::begin(bar),std::end(bar),std::begin(another_bar),[](T*item){return*T;});我认为这里发生了很多不必要的复制。编辑:T不是模板化参数。它是一个特定的类型。 最佳答案

c++ - 在 copy-and-swap 习语中实现交换

正在关注Whatisthecopyandswapidiom和Howtoprovideaswapfunctionformyclass,我尝试像后者接受的答案选项2那样实现交换函数(具有调用成员函数的自由函数),而不是前一个链接中的直接友好自由函数。但是下面的不编译#include//Uncommentingthefollowingtwolineswon'tchangethestateofaffairs//classBar;//voidswap(Bar&,Bar&);classBar{public:Bar(unsignedintbottles=0):bottles(bottles){enf

c++ - 顺序新建和删除

继续我的previousquestion,我想请教以下问题:给定一个C++函数,其中有一个new语句但没有显式返回任何内容(即使用return语句),它是否也应该始终有一个delete?如果不是,能否请您举个例子。 最佳答案 它不必显式返回新创建的对象,但它应该以某种方式将其传递给其他对象。可能的场景包括:在成员函数中,创建一个对象并将其分配给包含对象的字段。例子:classFoo{private:Baz*baz;public:Foo():baz(0){}voidcreate_bar(){baz=newBaz();}~Foo(){d

c++ - 为什么在 : foo x( (bar()) ); 这样的构造函数调用中需要双括号

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whyisitanerrortouseanemptysetofbracketstocallaconstructorwithnoarguments?我看到了C++FQAentries关于嵌套的构造函数调用和支撑,并且一直想知道C++解析器如何解析两个以及为什么解析器无法解析它。所以我明白了为什么fooxxx();是模棱两可的。但是是什么让foox(bar());模棱两可,因为它显然不是前向声明。(即:应该有一个语法可以成功检测到这一点)。有人能解释一下C++语法那部分的局限性和歧义吗?

c++ - 返回对齐结构后出现段错误

我提出的问题的最小实例如下:struct__attribute__((aligned(16)))Foo{floatx,y,z;Foo(floatx,floaty,floatz):x(x),y(y),z(z){}};classBar{public:Foofoo;Bar(constFoo&foo):foo(foo){}Foobar(){returnfoo;}};intmain(){Bar*bar=newBar(Foo(0.0f,0.0f,0.0f));bar->bar();return0;}如果使用clang++(版本3.4,Ubuntu14.04中的默认版本)编译,这段代码在运行时会导致

c++ - 我能保证不会被这种 ODR 违规行为所困扰吗?

我有一个头文件,它声明了一个带有静态变量的模板并定义了它:/*my_header.hpp*/#ifndefMY_HEADER_HPP_#defineMY_HEADER_HPP_#includetemplatestructfoo{staticintbar;staticvoiddump(){printf("%d\n",bar);}};templateintfoo::bar;#endif//MY_HEADER_HPP_此header包含在main.cpp和共享库mylib中。特别是,mylib_baz.hpp只包含此模板并声明一个修改模板特化的函数。/*mylib_baz.hpp*/#ifn

c++ - 从父类(super class)调用子类中的虚函数

我知道这个问题一定被无数次问过,但我搜索了以前的问题,似乎什么也没有。它是关于C++中的继承和虚函数。我在从父类(superclass)的子类中调用虚函数时遇到问题。我举个例子。从三个相互继承的类开始。classA{voidfoo(){bar()}virtualvoidbar(){}};classB:publicA{virtualvoidbar(){}};classC:publicB{virtualvoidbar(){//dosomething}};现在我想要一个声明为B*但实例化为C*的变量。B*myObject=newC();myObject->foo();当我这样做并在myObj