草庐IT

look_back

全部标签

c++ - 警告级别为 3 的 int 的 std::vector push_back 处的编译器警告

我使用的是英特尔C++编译器icc版本18.0.3。如果我编译followingcode使用-w3#includeintmain(){std::vectorvec;vec.push_back(2);return0;}test_w3.cpp(6):remark#383:valuecopiedtotemporary,referencetotemporaryusedvec.push_back(2);Replacing2有一个const变量as#includeintmain(){std::vectorvec;constinta=2;vec.push_back(a);return0;}不发出警告

c++ - 可以使用 vector.back() 为 vector 的最后一个元素赋值吗?

作为特殊情况,我有一些代码需要分配vector的第一个和最后一个元素。somevector.back()是左值吗?下面的代码可以工作吗?some_vector.front()=first_value;some_vector.back()=last_value; 最佳答案 是的,它可以,因为它返回对最后一个元素的引用。最好先确保它不是空的! 关于c++-可以使用vector.back()为vector的最后一个元素赋值吗?,我们在StackOverflow上找到一个类似的问题:

c++ - Push_back 比 insert 快?

我正在使用std::deque。我确信用单个insert替换带有push_back的循环会提高性能。也推荐,比如here.但现在我不再那么确定了。我对测试代码运行了一些基准测试。主要.cpp:#include"queueInsert.h"#includestd::dequequeue;constexprsize_tlen=64;intarr[len];intmain(){DWORDstartTime=GetTickCount();for(inti=0;i队列插入.h:#includevoidinsert(std::deque&,int*arr,intn);queueInsert.cpp

c++ - 将指针 push_back 到指针 vector 中是内存泄漏吗?

在我的类中,我有一个成员变量std::vectorchildren下面的类成员函数会造成内存泄漏吗?//addsachildnode{node*child=newnode("blah","blah","blah");child->Set_Parent(this);children.push_back(child);//vector复制了一个指针,我有两个指向同一内存的指针,然后原始指针超出范围,对吗?这可能简单明了,但我只想确认我的假设。谢谢 最佳答案 这不是泄漏……还不是。但是,如果vector超出范围,或者你erase,pop_

c++ - push_back() 和 resize(size()+1) 有区别吗

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。通过执行以下任一操作,可以扩展标准vector以容纳更多成员:std::vectorv;v.push_back(1);或intos=v.size();v.resize(os+1);v[os]=1;除了使用push_back()的代码简洁之外,还有其他区别吗?例如,一种比另一种更有效,还是在每种情况下分配的额外内存不同?

c++ - std::vector push_back(Object()) 和 push_back(new Object()) 的区别?

在我当前的代码中,我想将新的DrawObjects插入到我创建的vector中,std::vector对象;有什么区别:objects.push_back(DrawObject(name,surfaceFile,xPos,yPos,willMoveVar,animationNumber));和objects.push_back(newDrawObject(name,surfaceFile,xPos,yPos,willMoveVar,animationNumber)); 最佳答案 第一个添加非指针对象,而第二个添加指针到vector。

c++ - GCC 和 VC++ 之间 std::vector::emplace_back 的区别

这个问题在这里已经有了答案:Canstd::vectoremplace_backcopyconstructfromanelementofthevectoritself?(3个答案)关闭7年前。我听说ModernC++的建议之一是使用emplace_back而不是push_back来追加到容器中(emplace_back接受容器中存储类型的任何构造函数的任何版本参数。根据标准草案N379723.3.6.5(1),说:Remarks:Causesreallocationifthenewsizeisgreaterthantheoldcapacity.Ifnoreallocationhappe

c++ - std::make_unique(以及 emplace、emplace_back)对 initializer_list 参数的笨拙推导

假设我有这个结构:structposition{intx,y;};和另一个将this作为构造函数参数的类:classpositioned{public:positioned(positionp):pos(p){}private:positionpos;};我怎样才能得到简单的autobla=std::make_unique({1,2});上类?目前,编译器试图通过initializer_list匹配并调用make_unique的数组变体,这很愚蠢,因为positioned只有一个构造函数。emplace出现同样的问题和emplace_back功能。几乎所有将其可变模板参数转发给类的构造

c++ - 为什么 emplace_back ("Hello") 调用 strlen?

Justin'sanswer在另一个问题上做了一个我觉得很有趣但无法解释的观察。考虑以下代码:std::vectorv;v.push_back("Hello,world!");//Doesn'tcallstrlen.v.emplace_back("Hello,world!");//Callsstrlen.如果您查看程序集,emplace_backgeneratesacalltostrlen,而push_backdoesnot(使用-Ofast在gcc8.1和clang6.0中测试)。为什么会这样?为什么不能emplace_back优化strlen在这里打电话?我最初的想法是push_b

c++ - 类导出错误(错误 C2470 : looks like a function definition)

我无法导出类:#ifndefSDBIDI#defineSDBIDI#ifndefSDBIDI_FLAG#defineSDBIDI_ORIENT__declspec(dllimport)#else#defineSDBIDI_ORIENT__declspec(dllexport)#endif#include"TCInfoSuVars.h"//classishere!SDBIDI_ORIENTintmyFoo(FILE*file);//exportingfunction#endifTCInfoSuVars.h中的类定义#pragmaonce#include#includeclassSDBID