草庐IT

delete-orphan

全部标签

c++ - 对类中的方法正确使用 `= delete`

对于取消定义一个类的所有其他生成的方法和构造函数,以下代码段是否正确?structPicture{//'explicit':noaccidentalcastfromstringtoPictureexplicitPicture(conststring&filename){/*loadimagefromfile*/}//noaccidentalconstruction,i.e.temporariesandthelikePicture()=delete;//nocopyPicture(constPicture&)=delete;//noassignPicture&operator=(cons

c++ - 对类中的方法正确使用 `= delete`

对于取消定义一个类的所有其他生成的方法和构造函数,以下代码段是否正确?structPicture{//'explicit':noaccidentalcastfromstringtoPictureexplicitPicture(conststring&filename){/*loadimagefromfile*/}//noaccidentalconstruction,i.e.temporariesandthelikePicture()=delete;//nocopyPicture(constPicture&)=delete;//noassignPicture&operator=(cons

c++ - 是否有任何有效的用例可以在现代 C++ 中使用 new 和 delete、原始指针或 c 样式数组?

Here'sanotablevideo(StopteachingC)aboutthatparadigmchangetotakeinteachingthec++language.还有一篇值得注意的博文Ihaveadream...I'mdreamingofsocalledC++courses/classes/curriculaewillstopteaching(requiring)theirstudentstouse:...由于C++11作为既定标准,我们有Dynamicmemorymanagement设施又名智能指针。即使从早期的标准我们也有c++标准Containerslibrary作

c++ - 是否有任何有效的用例可以在现代 C++ 中使用 new 和 delete、原始指针或 c 样式数组?

Here'sanotablevideo(StopteachingC)aboutthatparadigmchangetotakeinteachingthec++language.还有一篇值得注意的博文Ihaveadream...I'mdreamingofsocalledC++courses/classes/curriculaewillstopteaching(requiring)theirstudentstouse:...由于C++11作为既定标准,我们有Dynamicmemorymanagement设施又名智能指针。即使从早期的标准我们也有c++标准Containerslibrary作

c++ - 为什么语言中内置了非放置 `new` 和 `delete` 而不仅仅是常规函数?

为什么没有展示newexpression和deleteexpression实现为语言内置而不是常规函数?如果我们有...向操作系统请求/归还内存的一种方式一种显式调用构造函数的方式(placementnew)一种显式调用析构函数的方式(~T())...为什么非放置new和delete不能只是标准库中的常规函数​​?示例:templateT*library_new(Ts&&...xs){auto*ptr=/*requestenoughmemoryfor`T`fromOS*/;new(ptr)T(std::forward(xs)...);returnptr;}templatevoidlib

c++ - 为什么语言中内置了非放置 `new` 和 `delete` 而不仅仅是常规函数?

为什么没有展示newexpression和deleteexpression实现为语言内置而不是常规函数?如果我们有...向操作系统请求/归还内存的一种方式一种显式调用构造函数的方式(placementnew)一种显式调用析构函数的方式(~T())...为什么非放置new和delete不能只是标准库中的常规函数​​?示例:templateT*library_new(Ts&&...xs){auto*ptr=/*requestenoughmemoryfor`T`fromOS*/;new(ptr)T(std::forward(xs)...);returnptr;}templatevoidlib

C++ 指针数组 : delete or delete []?

考虑以下代码:classFoo{Monster*monsters[6];Foo(){for(inti=0;i什么是正确的析构函数?这个:Foo::~Foo(){delete[]monsters;}或者这个:Foo::~Foo(){for(inti=0;i我目前有最上面的构造函数,一切正常,但我当然看不到它是否恰好在泄漏......就我个人而言,考虑到我正在做的事情,我认为第二个版本更合乎逻辑。无论如何,这样做的“正确”方法是什么? 最佳答案 删除[]怪物;不正确,因为monsters不是指向动态分配数组的指针,它是指针数组。作为类成

C++ 指针数组 : delete or delete []?

考虑以下代码:classFoo{Monster*monsters[6];Foo(){for(inti=0;i什么是正确的析构函数?这个:Foo::~Foo(){delete[]monsters;}或者这个:Foo::~Foo(){for(inti=0;i我目前有最上面的构造函数,一切正常,但我当然看不到它是否恰好在泄漏......就我个人而言,考虑到我正在做的事情,我认为第二个版本更合乎逻辑。无论如何,这样做的“正确”方法是什么? 最佳答案 删除[]怪物;不正确,因为monsters不是指向动态分配数组的指针,它是指针数组。作为类成

c++ - 当程序退出时,是否有理由在 C++ 中调用 delete?

在我的C++main函数中,例如,如果我有一个指向使用堆内存(而不是堆栈内存)的变量的指针-这会在我的应用程序退出后自动释放吗?我会这么认为。即便如此,始终删除堆分配是否是一种好习惯,即使您认为它们永远不会在退出时自动释放内存的情况下使用?例如,这样做有什么意义吗?intmain(...){A*a=newA();a->DoSomething();deletea;return0;}我在想也许,以防我重构(或其他人重构)该代码并将其放在应用程序的其他位置,而delete确实是必要的。除了BrianR.Bondy的回答(专门讨论了C++中的含义),PaulTomblin还有一个goodans

c++ - 当程序退出时,是否有理由在 C++ 中调用 delete?

在我的C++main函数中,例如,如果我有一个指向使用堆内存(而不是堆栈内存)的变量的指针-这会在我的应用程序退出后自动释放吗?我会这么认为。即便如此,始终删除堆分配是否是一种好习惯,即使您认为它们永远不会在退出时自动释放内存的情况下使用?例如,这样做有什么意义吗?intmain(...){A*a=newA();a->DoSomething();deletea;return0;}我在想也许,以防我重构(或其他人重构)该代码并将其放在应用程序的其他位置,而delete确实是必要的。除了BrianR.Bondy的回答(专门讨论了C++中的含义),PaulTomblin还有一个goodans