草庐IT

auto-delete

全部标签

c++ - std::move 与 std::auto_ptr 相比?

我可以用C++11中的“移动”(右值引用)做什么我不能用std::auto_ptr做什么?(据我了解,它们是一个想法的不同实现。)老问题又来了:std::auto_ptr是这么糟糕的组件吗? 最佳答案 C++98/03没有真正“可移动”类的概念。auto_ptr是一个具有transfer-on-copy-semantics的类,即当您制作拷贝时,原始内容会发生变化(注意带有非常量参数的复制构造函数!)。这是不好的。这样的类不能在标准容器中使用。由于新添加的右值引用概念,C++11引入了真正可移动类的概念。新的unique_ptr完全

c++ - 使用 auto 声明变量和使用类型名称有什么区别?

例如,我有一些类DataPacket。有什么区别:autopacket=DataPacket();和DataPacketpacket;? 最佳答案 先回答关于auto的问题,生成的代码没有区别:autopacket=DataPacket();和DataPacketpacket=DataPacket();但这不是你写的。在最初的问题中,第一个创建一个value-initialized临时对象,然后从中复制初始化packet。这需要一个可访问的、非显式的复制或移动构造函数,需要类型可以是默认构造的,并确保初始化packet(假设复制/移

c++ - C++中的delete如何知道要删除多少个内存位置

删除运算符是如何工作的?它比free()更好吗?此外,如果您执行ptr=newchar[10],然后使用deleteptr删除,指针如何知道要删除多少个位置。 最佳答案 只有delete操作符,free只作为函数存在。在C++下,我们鼓励您使用new/delete而不是malloc()/free()。删除运算符有一个内部的“魔法”。当使用new[]创建数组时,数组的大小存储在内存块的元数据中。delete[]使用该信息。所有这些当然都依赖于编译器、操作系统、优化器和实现。 关于c++-C

c++ - 如果使用 delete 而不是 free 删除使用 malloc 分配的内存怎么办

我遇到了一个我无法解决的问题。我的问题是,如果我使用malloc分配内存,然后使用delete删除内存块?一般的经验法则是Ifweallocatememoryusingmalloc,itshouldbedeletedusingfree.Ifweallocatememoryusingnew,itshouldbedeletedusingdelete.现在,为了检查如果我们反过来会发生什么,我写了一个小代码。#include#include#includeusingnamespacestd;classA{intp=10;public:intlol(){returnp;}};intmain()

c++ - 哪个版本的 safe_delete 更好?

#defineSAFE_DELETE(a)if((a)!=NULL)delete(a);(a)=NULL;或templatevoidsafe_delete(T*&a){deletea;a=NULL;}或者其他更好的方式 最佳答案 我不会说两者都不是,因为两者都会给您一种虚假的安全感。例如,假设您有一个函数:voidFunc(SomePtr*p){//stuffSafeDelete(p);}您将p设置为NULL,但函数外的p拷贝不受影响。但是,如果您必须这样做,请使用模板-宏总是有可能影响其他名称。

c++ - 有没有办法让 "delete"成为一个纯虚函数?

我有一个带有几个纯虚函数的抽象类,我从它派生的类之一不使用其中一个纯虚函数:classderivative:publicbase{public:intsomevariable;voidsomefunction();};无论如何,当我尝试编译它时,我得到一个错误(显然,如果从抽象类派生并且不覆盖所有纯虚函数,类仍然被认为是抽象的)。无论如何,定义一个函数似乎毫无意义intpurevirtfunc(){return0;}只是因为它需要通过技术来定义。无论如何从抽象类派生类而不使用抽象类的纯虚函数之一? 最佳答案 如果派生类不“使用”基类

c++ - 为什么 std::shared_ptr 从基类和派生类调用析构函数,而 delete 只调用基类的析构函数?

这个问题在这里已经有了答案:Howisitpossible(ifitis)toimplementshared_ptrwithoutrequiringpolymorphicclassestohavevirtualdestructor?(3个答案)关闭8年前。为什么在使用std::shared_ptr释放时从基类和派生类调用析构函数,而第二个示例仅从基类调用析构函数?classBase{public:~Base(){std::coutsharedA(newDerived);}std::cout输出:--------------------DeriveddestructorBasedestr

c++ - 在类中使用返回 auto 的静态 constexpr 成员函数

我正在尝试解决我遇到的MSVC2015中的错误(请参阅此问题:wrongtypedeductionoffunctionsignature).所以我想到了这个:#includenamespacewreg{usingt_oshandle=HKEY;structt_api{staticconstexprautofnc_open_key(){return::RegOpenKeyExA;}//thisdoesn'tcompile:staticconstexprautoopen_key=fnc_open_key();//thesedon'tcompileeither://staticconstex

c++ - 引用 "auto"函数作为模板参数

这是重现问题的最小(C++14)代码:templatestructFoo{staticautovalue(){}};voidbar(){}templatestructFoo::value>;GNUC++“g++(Ubuntu5.1.0-0ubuntu11~14.04.1)5.1.0”编译器发出:error:couldnotconverttemplateargument‘Foo::value’to‘void(&)()’templatestructFoo::value>;^我注意到的第一个奇怪的事情是Foo::value—a未被替换,并且value不知何故变成了模板?以下无意义的修复强化了

【C++】 C++入门 — auto关键字

C++入门auto关键字1介绍2使用细则3注意事项Thanks♪(・ω・)ノ谢谢阅读下一篇文章见!!!auto关键字1介绍编程时常常需要把表达式的值赋给变量,这就要求在声明变量时清楚地知道表达式的类型。然而要做到这一点并非那么容易,有时甚至做不到。如下:类型难于拼写含义不明确导致容易出错#include#includeintmain(){ std::mapstd::string,std::string>m{{"apple","苹果"}, {"orange","橙子"}, {"pear","梨"}}; std::mapstd::string,std::string>::iteratorit=m