草庐IT

c++ - 通过 new 赋值一个复杂的构造函数

我有一个困惑。以下是一段代码。我想使用new创建一个包含五个类对象的动态数组,但我想运行一个循环以使用循环计数器分配构造函数的第一个参数。类似的东西。classA{public:A(int_x,int_y):x(_x),y(_y){}private:intx,y;};intmain(){A*a=newA[5];//compilererrorfor(i=0;i谁能告诉我正确的语法是什么,因为我没有简单的构造函数? 最佳答案 这一行A*a=newA[5];要求A是默认可构造的。因此,一个简单的选择是将默认构造函数添加到A:A():x()

c++ - C/C++ : extract a subset of one enum to form a new enum

假设我有一个列出所有人员的主枚举:typedefenumall_personnel{//maleTONY,MIKE,JIM,//femaleJESSICA,MARY,}all_personnel_t;现在我想为male和female定义其他两个枚举(因为,例如,一些函数只接受males或females枚举参数),但我想使用与主枚举中相同的名称标识符。在C/C++中有可能吗?还是有其他方法?似乎以下内容不起作用(编译器提示redeclarationofenumerator‘TONY’等:typedefenummale_personnel{TONY,MIKE,JIM,}male_perso

c++ - operator new 已经有一个主体

我正在尝试将参数作为全局参数来实现operatornew。如果没有args的new重载没有问题,但是在尝试编译时出现以下错误inlinevoid*operatornew(size_t,void*p){//...returnp;}c:\bjarne_exercise_6.cpp(14):errorC2084:function'void*operatornew(size_t,void*)throw()'alreadyhasabodyc:\programfiles\microsoftvisualstudio10.0\vc\include\new(55):seepreviousdefiniti

c++ - 如果使用 'new' 来实例化对象而不将其分配给变量,会发生什么情况?

想问一下如果我写下面的程序运行程序会怎样newint[5];//withoutassigningittoapointer.编译通过。但是会分配一个5*sizeof(int)内存块吗?如果是对象呢?newsome_obj_[5];//withoutassigningittoapointer.some_obj_的构造函数会被调用吗? 最佳答案 newint[5];//withoutassigningittoapointer.是的,将分配一个5*sizeof(int)内存块,但您无法访问,因为您没有保存指针。你会发生内存泄漏。newsom

c++ - std::string 和 placement new

我发现了这个在C++中使用placementnew的例子,它对我来说没有意义。我认为这段代码容易出现异常,因为可能会使用比分配的内存更多的内存。char*buf=newchar[sizeof(string)];string*p=new(buf)string("hi");如果“string”是C++STD::string类,那么buf将得到一个分配空字符串对象的大小(我的编译器给出了28个字节),然后我看到它的方式如果你用更多的字符初始化你的字符串你可能超过分配的内存。例如:string*p=new(buf)string("hiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii

c++ - `void f1(const Class &c)` 和 `void f2(Class const &c)` 有什么区别?

下面这些函数有什么区别(看关键字const)?voidf1(constClass&c)和voidf2(Classconst&c) 最佳答案 没有区别。这两个版本可以互换。 关于c++-`voidf1(constClass&c)`和`voidf2(Classconst&c)`有什么区别?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7576223/

c++ - Object var 和 Object* var = new Object() 的区别

如果我有一个名为Object的类,那么创建一个这样的实例有什么区别:Objectvar;和:Object*var=newObject();? 最佳答案 此处您在堆栈上创建了var:Objectvar;所以在上面,var是实际的对象。此处您在堆上创建var(也称为动态分配):Object*var=newObject()在堆上创建对象时,必须在使用完后对其调用delete。此外,var实际上是一个指针,它保存着类型为Object的对象的内存地址。在内存地址存在实际对象。更多信息:Seemyanswerhereonwhatandwhere

c++ - 为什么我们不能在没有 new 关键字的情况下在 Qt 中创建对象(即在堆栈上)?

为什么我们不能在没有new关键字的情况下在QT中创建对象?通常我们创建指向对象的指针,如下所示:QLabel*ql=newQLabel();ql->show()但我想创建一个这样的对象:QLabelql=QLabel();ql.show()这可能吗? 最佳答案 问题在于Qt控件(标签、按钮)处于层次结构中(例如,按钮属于窗体)。而Qt的实现方式要求当一个对象被销毁时,属于它的所有对象也会被销毁。如果您将对象放在堆栈上(这就是“不使用new关键字创建”的真正调用方式),它们将自动销毁。这是C++的特性,它适用于所有程序。如果您在堆栈上

c++ - 是否可以使用 operator new 从堆以外的其他地方进行分配?

这是我的应用程序的上下文:我正在开发一个使用来自不同设备的RAM的嵌入式系统。一部分在微Controller的内部RAM(128kB)中,另一部分是外部RAM(1MB)。这些内存映射到微Controller的地址空间,但位于非连续区域。内部RAM用于系统堆栈、任务堆栈和堆。外部RAM用于静态分配的数据(池、缓冲区和所有“static...”内容)我正在尝试实现一个简单的内存管理结构,并且作为它的一部分能够创建一个分配器,该分配器可以使用operatornew的分配算法但使用另一个内存源,而不是系统heap而是其他地方的内存区域。你知道这是否可能吗?一个使用示例可以是保留100kB的外部

c++ - 玩具垃圾收集 : Is operator new/delete enough?

我正在研究我的一个学习项目(使用C语言),并考虑将其迁移到C++以获得额外的学习点。它的一部分涉及针对特定对象系列的垃圾收集系统,在C中,我通常会使用大型malloc/mmap并使用简单的天真标记和清除(我可以识别引用和类似的东西)已经)。我的问题是我正在考虑将这个想法转移到C++,但我对我对其内存管理方案的理解不够安全。到目前为止,我考虑分配一个大内存池并在基类上重载运算符new和delete以调用我的内存池的抓取/释放函数,然后让垃圾收集器的清理阶段删除它看到的对象。够了吗?我在这里没有看到的隐藏陷阱是什么?编辑:澄清一下,我已经能够计算出分配对象的生命周期,因此无需使用gcabi