草庐IT

ctor-initialiser

全部标签

c++ - 为什么调用了错误的 ctor?

我有按预期工作的代码:EscapedStringes("Abc&def");EscapedStringes2("");es2=es;//es2==Abc%26def以及未按预期工作的代码:EscapedStringes("Abc&def");EscapedStringes2=es;//es==Abc%2526def在第二种情况下,即使es是EscapedString,也会调用CTOR2而不是CTOR3。EscapedStringes(EscapedString("Abc?def"));做正确的事,但我似乎无法在CTOR3上设置断点,所以我不确定它是否正常工作,或者代码已被优化掉或意外工

c++ - 调用复制 ctor 而不是移动 ctor

为什么从bar返回时调用复制构造函数而不是移动构造函数?#includeusingnamespacestd;classAlpha{public:Alpha(){cout如果bar执行returnmove(a)则行为符合预期。我不明白为什么调用std::move是必要的,因为foo在返回时调用移动构造函数。 最佳答案 在这种情况下有两件事需要理解:ainbar(Alpha&&a)是一个命名的右值引用;因此,被视为左值。a仍然是引用。第1部分由于bar(Alpha&&a)中的a是一个命名的右值引用,因此它被视为左值。将命名右值引用视为左

c++ - g++ 4.9.3 提示 friended ctor 对 .emplace_back() 是私有(private)的,但喜欢 .push_back()

我肯定遗漏了关于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;};

c++ - 来自 Base Ctor 的纯虚函数调用

考虑以下示例代码:#includeusingnamespacestd;classbase{public:base(){bar();//Line1this->bar();//Line2base*bptr=this;bptr->bar();//Line3((base*)(this))->bar();//Line4}virtualvoidbar()=0;};classderived:base{public:voidbar(){cout上面的代码在基类中有纯虚函数bar(),它在派生类中被重写了。纯虚函数bar()在基类中没有定义。现在关注Line1、Line2、Line3和Line4。我明白

c++ - 如何找到在 g++ 代码中调用给定成员函数或 ctor 的所有位置?

我试图在一个庞大而陈旧的代码库中找到所有调用了某些构造函数或函数的地方。具体来说,这些是std::string中的某些构造函数和成员函数。类(即basic_string)。例如,假设有一行代码:std::stringfoo(fiddle->faddle(k,9).snark);在这个例子中,看这个并不明显snark可能是char*,这是我感兴趣的。目前尝试解决这个问题我研究了gcc的一些转储功能,并生成了其中一些功能,但我没能找到任何告诉我给定代码行将生成对string的调用的信息。构造函数采用constchar*.我还使用-s编译了一些代码以保存生成的等效汇编代码。但这有两个问题:函

c++ - 在ctors中调用其他类的虚方法

在关于callingvirtualmethodsinctorsanddtors的问题中,以下一段源代码引用自C++标准:structV{virtualvoidf();virtualvoidg();};structA:virtualV{virtualvoidf();};structB:virtualV{virtualvoidg();B(V*,A*);};structD:A,B{virtualvoidf();virtualvoidg();D():B((A*)this,this){}};B::B(V*v,A*a){f();//callsV::f,notA::fg();//callsB::g,

c++ - 是否可以从 std::string 中获取内存(就像 string move ctor 那样)?

如果我的内部类是我自己的vector版本(我控制来源)并且为了举例,我不能将其更改为std::string有没有办法从std::string窃取内存,就像std::string的move构造函数一样做。所以像这样:std::stringstr{"abcdefghijklmnopqrstu"};MyVectorCharClassmvc(std::move(str));//Constructortakesmemoryfromstr我想我听说过一些future的建议,以添加.release()至std::string或std::vector但我说的是现在。 最佳答

c++ - 意外地能够从基类ctor调用派生类虚函数

任何人都可以帮助解释这种意外行为吗?前提我创建了包含成员std::thread变量的Thread类。Thread的构造函数构造成员std::thread,提供指向调用纯虚函数(由基类实现)的静态函数的指针。代码#include#include#includenamespace{classThread{public:Thread():mThread(ThreadStart,this){std::coutRun();}voidjoin(){mThread.join();}virtualvoidRun()=0;protected:std::threadmThread;};classVerbo

c++ - 为什么一个 ctor 不能调用另一个 ctor 来初始化对象

classFoo{public:Foo(){Foo(1)}Foo(intx,inty=0):i(x){}private:inti;}任何人都可以给我一些关于我可以这样做的理由吗?如果不是,为什么? 最佳答案 因为语言规范不允许。语言就是这样。如果您习惯使用Java或其他允许它的语言,那将非常烦人。但是,一段时间后您就会习惯它。所有语言都有其怪癖,这只是C++的其中一种。我相信规范的编写者有他们的理由。我发现最好的解决方法是创建一个通用的初始化函数并让两个构造函数都调用它。像这样:classFoo{public:Foo(){initi

iOS 和 OpenCV : how to initialise CvVideoCamera object to reflect UIImage size?

这是我用来将CvVideoCamera提要初始化到我的ViewController中的UIImageView对象的代码。我怎样才能让相机适应UIImageView的大小?就像现在一样,当View首先加载时相机略小,只有当我旋转屏幕时才会变大。-(void)viewDidLoad{[superviewDidLoad];//Doanyadditionalsetupafterloadingtheview,typicallyfromanib.self.videoCamera=[[CvVideoCameraalloc]initWithParentView:imageView];self.vide