草庐IT

foo_impl

全部标签

c++ - vector<shared_ptr<Foo>> 到 vector<shared_ptr<const Foo>> 的隐式转换

根据thispage您可以隐式转换shared_ptr至shared_ptr.这很有道理。但是,当我尝试转换std::vector时遇到错误包含shared_ptr到一个包含shared_ptr的.有没有什么好的方法可以实现这种转化? 最佳答案 编号:std::vector>和std::vector>是不同的类型,因此您不能将一种类型的对象视为另一种类型的对象。如果你真的需要std::vector>,你可以很容易地用shared_ptr创建一个s到与原始元素相同的元素:std::vector>v;std::vector>cv(v.b

c++ - 如何在 C++ 中调用 void foo(int (&)[]) {}?

voidf1(int(&)[8]){}voidf2(int(&)[]){}intmain(){inta[8];f1(a);//OKf2(/*WhatshouldIputhere?*/);//???return0;}如何调用f2?PS:voidf2(int(&)[]){}在VC++2012下是合法的。考虑以下几点:templatestructA{};templatestructA{};templatestructA{}; 最佳答案 C++有一个明确的规则,不允许将没有边界的数组引用或指针作为参数(但这些是其他有效类型)。以下将是此类参

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

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

c++ - 函数异常规范和标准异常 - foo() throw(Exception)

在C++中,您可以像这样声明具有异常规范的函数:intfoo()constthrow(Exception);我找到了这两个链接:http://www.cplusplus.com/doc/tutorial/exceptions/和http://publib.boulder.ibm.com/infocenter/lnxpcomp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8l.doc%2Flanguage%2Fref%2Fcplr156.htm但有几件事最终没有答案......问题1:为什么要添加异常规范?它会带来任何性能提升吗?编译器会有什么不同?因为

c++ - 错误 : Label "foo" used but not defined

所以我在使用一些C++代码时遇到了前面提到的错误,代码看起来有点像这样:#includeusingnamespacestd;charfoodstuffs;voidfruit(){cin>>foodstuffs;switch(foodstuffs){case'a':gotofoo;break;case'b':gotofooo;break;}}intmain(){cout确切的代码要复杂得多,但这只是为了向您展示我遇到的错误。现在我意识到每个人都出于某种原因鄙视“goto”语句,但我的实际代码中充满了太多的goto,以至于我真的没有时间/耐心回去更改它们。此外,我是一名新手程序员,我发现g

c++ - 对于模板类 Foo 方法的参数, "Foo&"和 "Foo<T>&"是否相同?

考虑类templatestructFoo{Foo(constFoo&other){}};对于构造函数参数类型,是constFoo&和constFoo&在这种情况下是否相同?我一直认为不是,认为后者可以称为Foof=Foo(),而前者不能。但现在我不确定是否是这样。 最佳答案 在一个类模板中,类模板参数对每个实例都有一个独特的含义。这意味着Foo有T==int,因此模板化的ctor是Foo::Foo(constFoo&other).虽然额外的模板参数是可能的:templatestructFoo{templateFoo(constFoo

c++ - 返回 vector<Foo> 或 shared_ptr<vector<Foo>>?

在一个函数中,哪个“return”更合适?一个。vector?B.shared_ptr>?换句话说,哪个文案不那么重,你会怎么做,为什么? 最佳答案 我想返回shared_ptr>很少有用。如果有几个对象可以保存它们可以操纵的共享vector,我只会这样做。对我来说,这表明存在设计缺陷。更好的选择可能是通过const引用返回。这避免了(可能很昂贵的)复制操作,但不允许访问者更改vector。如果您要返回本地std::vector您也可以通过参数返回它。如果真要回shared_ptr>,考虑是否shared_ptr>会完成这项工作(载

c++ - std::unordered_set<Foo> 作为类 Foo 的成员

我正在编写一个类,该类具有自己类型的unordered_set作为成员。因此我需要为hash编写特化.这个特化需要在声明Foo之后定义。但在我看来,好像我已经需要hash的特化了。在定义成员之前unordered_set.至少它不会编译并在那里失败。我尝试了哈希模板的前向声明,但也无法使其正常工作。相关代码片段为:classFoo{public:inti;std::unordered_setdummy;Peer(std::unordered_set);};namespacestd{templatestructhash{size_toperator()(constFoo&f)const{

c++ - 从 "foo<T>"转换为 "const foo<const T>"- C++

我有一个类似的函数(请不要关心通过引用返回临时值。这只是一个解释问题的例子),constfoo&get_const(){foof;returnf;}这显然无法编译。我正在寻找一种方法来确保调用者不会更改T的foo.我怎样才能确保这一点?我已经看到boost::shared_ptr的类似行为.shared_ptr可转换为constshared_ptr.我不知道它是怎么做到的。任何帮助都会很棒。 最佳答案 编译器看到foo和foo作为两种完全不同且不相关的类型,所以foo与任何其他转换一样,类需要明确支持这一点。如果您可以控制foo类,

c++ - (简单的构造函数概念)为什么 Foo(); 没有?做任何事情?

这是一个简单的C++构造函数概念,但我遇到了麻烦。鉴于此代码片段:#includeusingnamespacestd;classFoo{public:Foo(){cout输出是:Foo()~Foo()Foof2();似乎什么也没做。是什么Foof2();为什么它什么都不做? 最佳答案 Foof2();声明了一个名为f2的函数,它不接受任何参数并返回一个类型为Foo的对象还要考虑在Foo中也有一个复制构造函数的情况Foo(constFoo&obj){cout如果您尝试编写Fooobj(Foo()),在这种情况下,您可能会期望调用不正确