草庐IT

default_delete

全部标签

c++ - "delete this"到一个用 std::shared_ptr 分配的对象?

我知道,每当您使用传统指针为new分配内容时,都可以在C++中说deletethis。事实上,我也知道如果你小心处理它是很好的做法。如果对象被std::shared_ptr持有,我可以让对象说deletethis吗?那应该调用析构函数,对吗?给你一个想法,我正在制作一个游戏,其中一艘船可以发射导弹,我想让导弹自行删除。 最佳答案 不,这不安全,对象的生命周期是由shared_ptr的持有者决定的,所以对象本身不能决定它是否要消亡。如果你这样做,你会得到双倍的当最后一个shared_ptr死亡时删除。我能提供的唯一解决方案是“重新考虑

c++ - 删除数组时delete和delete[]是一样的吗?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicates:Howcouldpairingnew[]withdeletepossiblyleadtomemoryleakonly?(POD)freeingmemory:isdelete[]equaltodelete?使用gcc版本4.1.220080704(RedHat4.1.2-48)。还没有在VisualC++上测试过它。似乎delete和delete[]在删除“简单”类型的数组时效果相同。char*a=newchar[1024];delete[]a;//thecorrectway.nomemoryleak.cha

c++ - C++中new和delete的使用

我需要帮助来理解何时应该使用以下选项char*a=newchar();和char*a=newchar[sizeof(int)+1];以及应该如何进行相应的内存释放调用? 最佳答案 任何时候你使用newT,之后你必须在结果指针上调用delete。任何时候你使用newT[n],你都必须在之后对结果指针调用delete[]。这就是它的全部内容。但请注意,您通常根本不应该使用它们。如果你需要一个字符串,不要分配一个字符数组。只需声明一个std::string(不使用new)。如果您需要一个大小在运行时确定的数组,请不要分配数组。声明一个st

c++ - 如何对两个指针指向的变量使用 delete?

假设我有一个用new声明的假想指针,如下所示:int*hypothetical_pointer=newint;并创建另一个具有相同值的假设指针:int*another_hypothetical_pointer=hypothetical_pointer;如果我要删除这些用new声明的指针,我是否必须删除两个指针,或者只删除用new显式声明的指针?或者我可以删除任一指针吗? 最佳答案 delete销毁指针指向的动态分配对象。有一个或100个指针指向该对象并不重要,您只能销毁一个对象一次。deletehypothetical_pointe

spring - <mvc :default-servlet-handler/>有什么需要和使用

需要什么在SpringMVC中。我们应该什么时候使用它。什么时候需要它。我们为什么要使用它。我在stackoverflow中浏览了几个链接,但无法获得清晰的图片或理解。谁能解释一下? 最佳答案 需要什么在SpringMVC?使用这个handlerspringdispatcher会将所有请求转发到默认Servlet.要启用该功能,您可以使用注释或基于xml的配置,如下所示:@Configuration@EnableWebMvcpublicclassWebConfigextendsWebMvcConfigurerAdapter{@Ove

spring - <mvc :default-servlet-handler/>有什么需要和使用

需要什么在SpringMVC中。我们应该什么时候使用它。什么时候需要它。我们为什么要使用它。我在stackoverflow中浏览了几个链接,但无法获得清晰的图片或理解。谁能解释一下? 最佳答案 需要什么在SpringMVC?使用这个handlerspringdispatcher会将所有请求转发到默认Servlet.要启用该功能,您可以使用注释或基于xml的配置,如下所示:@Configuration@EnableWebMvcpublicclassWebConfigextendsWebMvcConfigurerAdapter{@Ove

C++11 替代 boost::checked_delete

作为前向声明的重度用户,我喜欢我的类在销毁时完成。为确保这一点,我将析构函数设为私有(private)并与boost::checked_delete成为friend:#includestructMyClass{//MyClass'sinterfaceprivate:~MyClass(){/*something*/}friendvoidboost::checked_delete(MyClass*x);};在C++11中,std::default_delete还在销毁时检查完整性。然而,我无法实现与上面相同的行为:#includestructMyClass{//MyClass'sinter

c++ - 私有(private)转换函数导致 "ambiguous default type conversion"错误 (c++)

首先,一个演示问题的小例子:structBar{enumBaz{aa,bb,cc};Bazbaz_;operatorBaz()const{returnbaz_;}private:templateoperatorT()const;};intmain(){Barbar;switch(bar){caseBar::aa:break;caseBar::bb:break;caseBar::cc:break;default:break;}return0;}使用g++4.7.0编译此代码会出现以下错误:foo.cpp:Infunction‘intmain()’:foo.cpp:12:16:error:

c++ - c++ operator new[]/delete[] 是否调用 operator new/delete?

C++operatornew[]/delete[](不是我的)是否调用operatornew/delete?在我用自己的实现替换operatornew和operatordelete之后,下面的代码将调用它们:int*array=newint[3];delete[]array;并且当我也替换了operatornew[]和operatordelete[]时,上面的代码将只调用他们。我的运营商实现:void*operatornew(std::size_tblockSize){std::cout(block);blockSize=blockSize-sizeof(int);std::cout(

c++ - 格式化 float : returning to default

在返回“默认格式”的意义上,我遇到了浮点值的格式问题。假设我有2个花车:floatf1=3.0f,f2=1.5f;std::cout将这些显示为:3-1.5现在,出于某种原因,我需要在std::cout上设置精度(用于其他打印):cout如果我再次打印我的两个float,这将导致:3.00-1.50现在我想恢复默认格式。在C++11之前,这似乎很困难(或者是吗?)。但是,谢谢,我现在有了这个新标志:std::defaultfloat.让我们试试:std::cout将打印:3-1.50。很好。哦,但是等等。假设我有:floatf1=444.0f,f2=444.5f;默认打印会显示:444