草庐IT

expose_new

全部标签

c++ - int *array = new int[n];这个函数实际上在做什么?

我对如何创建动态定义的数组感到困惑:int*array=newint[n];我不知道这是在做什么。我可以说它正在创建一个名为数组的指针,它指向一个新的对象/数组int?有人愿意解释一下吗? 最佳答案 new分配存储您请求的对象/数组所需的内存量。在这种情况下,n个整数。然后指针会将地址存储到这block内存。但是要小心,这个分配的内存块在你写出来之前不会被释放delete[]array; 关于c++-int*array=newint[n];这个函数实际上在做什么?,我们在StackOve

c++ - int *array = new int[n];这个函数实际上在做什么?

我对如何创建动态定义的数组感到困惑:int*array=newint[n];我不知道这是在做什么。我可以说它正在创建一个名为数组的指针,它指向一个新的对象/数组int?有人愿意解释一下吗? 最佳答案 new分配存储您请求的对象/数组所需的内存量。在这种情况下,n个整数。然后指针会将地址存储到这block内存。但是要小心,这个分配的内存块在你写出来之前不会被释放delete[]array; 关于c++-int*array=newint[n];这个函数实际上在做什么?,我们在StackOve

c++ - Qt: "new without delete"是否会导致控件的内存泄漏?

我正在查看Qt示例here:在构造函数内部,它们有:Window::Window(){editor=newQTextEdit();//Memoryleak?QPushButton*sendButton=newQPushButton(tr("&Sendmessage"));//Memoryleak?connect(sendButton,SIGNAL(clicked()),this,SLOT(sendMessage()));QHBoxLayout*buttonLayout=newQHBoxLayout();//Memoryleak?buttonLayout->addStretch();bu

c++ - Qt: "new without delete"是否会导致控件的内存泄漏?

我正在查看Qt示例here:在构造函数内部,它们有:Window::Window(){editor=newQTextEdit();//Memoryleak?QPushButton*sendButton=newQPushButton(tr("&Sendmessage"));//Memoryleak?connect(sendButton,SIGNAL(clicked()),this,SLOT(sendMessage()));QHBoxLayout*buttonLayout=newQHBoxLayout();//Memoryleak?buttonLayout->addStretch();bu

c++ - 可以使用placement-new 和vector::data() 替换 vector 中的元素吗?

关于替换不可赋值的vector元素存在两个问题:C++UseUnassignableObjectsinVectorHowtopush_backwithoutoperator=()forconstmembers?一个对象不可赋值的一个典型原因是它的类定义包含const成员,因此它的operator=被删除了。std::vector要求其元素类型是可分配的。事实上,至少使用GCC,既不是直接赋值(vec[i]=x;),也不是erase()和insert()当对象不可分配时替换元素有效。可以像下面这样使用vector::data()、直接元素销毁和使用复制构造函数放置new的函数来替换元素而

c++ - 可以使用placement-new 和vector::data() 替换 vector 中的元素吗?

关于替换不可赋值的vector元素存在两个问题:C++UseUnassignableObjectsinVectorHowtopush_backwithoutoperator=()forconstmembers?一个对象不可赋值的一个典型原因是它的类定义包含const成员,因此它的operator=被删除了。std::vector要求其元素类型是可分配的。事实上,至少使用GCC,既不是直接赋值(vec[i]=x;),也不是erase()和insert()当对象不可分配时替换元素有效。可以像下面这样使用vector::data()、直接元素销毁和使用复制构造函数放置new的函数来替换元素而

c++ - 了解 new-handler 的行为

我正在阅读ScottMeyers的EffectiveC++55,并且有一个来自第49条的问题:当operatornew无法满足内存请求时,它会调用重复new-handler函数,直到找到足够的内存。设计良好的newhandler函数必须执行以下操作之一:提供更多可用内存。安装不同的新处理程序。卸载新的处理程序抛出异常不返回当new无法分配内存时,说明内存不足,问题是newhandler如何以及从哪里分配更多的内存?你能解释一下所有这些步骤吗? 最佳答案 这取决于实现。我可以告诉你我通常的做法:1)新处理程序在启动时分配大量内存作为保

c++ - 了解 new-handler 的行为

我正在阅读ScottMeyers的EffectiveC++55,并且有一个来自第49条的问题:当operatornew无法满足内存请求时,它会调用重复new-handler函数,直到找到足够的内存。设计良好的newhandler函数必须执行以下操作之一:提供更多可用内存。安装不同的新处理程序。卸载新的处理程序抛出异常不返回当new无法分配内存时,说明内存不足,问题是newhandler如何以及从哪里分配更多的内存?你能解释一下所有这些步骤吗? 最佳答案 这取决于实现。我可以告诉你我通常的做法:1)新处理程序在启动时分配大量内存作为保

c++ - C++ 中的 "new (&variable) value;"有什么作用?

假设我在C++程序中有以下代码:Objecta=Object(someParameters);new(&a)Object(someOtherParameters);我的假设是它将a的内容替换为Object(someOtherParameters),避免为声明可能的operator=对象。这是正确的吗? 最佳答案 它叫做placementnew.它在指定内存上调用构造函数,而不是分配新内存。请注意,在这种情况下,您必须在释放分配的内存之前显式调用对象的析构函数。澄清。假设你分配了一些原始内存char*rawMemory=newchar

c++ - C++ 中的 "new (&variable) value;"有什么作用?

假设我在C++程序中有以下代码:Objecta=Object(someParameters);new(&a)Object(someOtherParameters);我的假设是它将a的内容替换为Object(someOtherParameters),避免为声明可能的operator=对象。这是正确的吗? 最佳答案 它叫做placementnew.它在指定内存上调用构造函数,而不是分配新内存。请注意,在这种情况下,您必须在释放分配的内存之前显式调用对象的析构函数。澄清。假设你分配了一些原始内存char*rawMemory=newchar