草庐IT

new_setting

全部标签

c++ - new() 是否也为类的函数分配内存?

classAnimal{public:inta;doubled;intf(){return25;}};假设上面的代码,我尝试通过说newAnimal()来初始化一个对象,这个new()是否也为函数分配内存f()?换句话说,如果我改用这个类并执行newAnimal(),在内存分配方面有什么不同?:classAnimal{public:inta;doubled;}; 最佳答案 对于没有虚函数的类,函数本身不占用数据空间。函数是可以执行以操作数据的代码段。必须分配的是数据成员。当你有一个虚类时,通常会有一个额外的虚表指针。请注意,vtab

c++ - 历史代码中异常使用 new。这是什么意思?

我只是移植了一些旧代码:#defineNewArrayOnHeap(TYPE,COUNT,HEAP,NEWPTR,ERROR)\((*(NEWPTR)=new(#TYPE"["#COUNT"]",__alignof(TYPE),(HEAP),&hr,(ERROR))TYPE[COUNT]),hr)看起来原来应该定义他们自己的神奇new运算符。我很好奇这种用法。示例用法intmain(){void*heap=/*Don'tknowhowtodefinethis*/double*ptr;HRESULThr;hr=NewArrayOnHeap(double,10,heap,ptr,"Help

c++ - 正确重载 new/delete new[]/delete[]

这是我之前问题的后续,Initializingaclassusingmalloc接受的问题答案有效并在avr-gcc上给我新建/删除,这是问题所在,但我重载的新删除对常规gcc造成严重破坏,重载新删除的正确方法是什么我所有的类派生自一个通用的基类,所以理想情况下我只想为我的对象覆盖新的删除,这样它就不会与STLstdlib等混淆。 最佳答案 'new'和'delete'可以在公共(public)Object基类中重载。因此,这将仅适用于该层次结构。classObject{public:void*operatornew(size_ts

c++ - 为什么boost mpl set允许非唯一类型

我相信我对boost::mpl::set的理解存在根本性的缺陷。我以为它只允许唯一类型。但是下面的代码可以编译:#include#include#include#include#include#include#include#includeusingnamespaceboost::mpl;typedefsetmy_set;//longrepeatedinset?typedefvectormy_vec;//seemsreasonabletypedefaccumulate,plus>>::typeset_size;typedefaccumulate,plus>>::typevec_size

c++ - 如何使用 const getter 对 std::set 进行排序

我有一个std::set容器,其元素是以下类的对象:classLaneConnector{public:constLane*getLaneFrom()const{returnFrom;}constLane*getLaneTo()const{returnTo;}private:Lane*From;Lane*To;}我的比较函数如下:structMyLaneConectorSorter{booloperator()(LaneConnector*c,LaneConnector*d){Lane*a=const_cast(c->getLaneFrom());Lane*b=const_cast(d

c++ - operator new 负数

在C++11中,如果我们尝试使用全局运算符new分配负大小的数组,它会抛出std::bad_array_new_length,但是C++98/C++03呢?是UB还是会抛出std::bad_alloc?intmain(){int*ptr=newint[-1];} 最佳答案 如果大小为C++03标准的负数5.3.4p6,则程序不正确:Everyconstant-expressioninadirect-new-declaratorshallbeanintegralconstantexpression(5.19)andevaluateto

c++ - 编写可以使用 std::vector 或 std::set 的模板

我编写了一个异步作业队列类,多年来一直运行良好。它使用std::vector作为底层集合来保存作业,然后按照您的预期稍后处理它们。当我添加作业时,它会在此vector上执行push_back。最近我决定要模板化它使用的底层集合类型以及我编写它的方式,这应该非常简单。现在声明如下:template>classasync_jobqueue{public:只有一个障碍,对于vector类型的容器,我想将东西推到集合的末尾并调用push_back,对于settish类型的容器,我想调用insert。我怎样才能做出关于调用哪个的编译决定?或者有没有我可以使用的方便的适配器?

c++ - 从 map<key, set<datatype>> 访问元素

我正在使用如下所示的数据结构:map>data;到目前为止,我在使用foreach循环处理map时没有遇到任何问题,但是,现在我需要像这样打印出map中的数据:KEY:elem1,elem2,elem3KEY2:elem1,elem2,elem3由于末尾缺少逗号,我不能再使用foreach循环了(可以吗?)。由于我是C++、C++11及其提供的所有乐趣的新手,所以我很迷茫。我想到了:for(autoi:data){cout我知道自己想要什么,只是对语法一无所知,C++引用也帮不上什么忙。感谢您的回答,同时我将自己浏览C++引用资料。 最佳答案

c++ - 是否有任何 std::set 实现不使用红黑树?

有没有人见过STL的实现,其中STL::set不是实现为红黑树?我问的原因是,在我的实验中,B树优于std::set(和其他红黑树实现)2到4倍,具体取决于值B.我很好奇,当似乎有更快的数据结构可用时,是否有令人信服的理由使用红黑树。 最佳答案 Google的一些人实际上构建了一个B-treebasedimplementationoftheC++standardlibrarycontainers.它们的性能似乎比标准二叉树实现要好得多。不过有一个问题。C++标准保证从映射或集合中删除元素只会使指向映射或集合中相同元素的其他迭代器无效

c++ - 迭代 boost::icl::interval_set

我正在迭代boostinterval_set,我期望每个迭代器都是一个boostinterval,其值将通过upper访问和lower方法:boost::icl::interval_setoutages;//...//Insertintervalsintothedatabasefor(boost::icl::interval_set::iteratorit=outages.begin();it!=outages.end();it++){DATA_ACQUISITION::InsertInterval(db,it->lower(),it->upper())}但我在两个lower都收到错误