草庐IT

link-delete

全部标签

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++ - 什么时候加载 DLL : Implicit Linking VS Explicit Linking

我认为隐式链接会在应用程序启动时立即加载DLL,因为它也称为“加载时动态链接”。但是我在下面的链接中发现了一些奇怪的解释(https://msdn.microsoft.com/en-us/library/253b8k2c(VS.80).aspx)。隐式链接Liketherestofaprogram'scode,DLLcodeismappedintotheaddressspaceoftheprocesswhentheprocessstartsupanditisloadedintomemoryonlywhenneeded.Asaresult,thePRELOADandLOADONCALLc

c++ - delete[] (ptr, 0) 的行为

是否定义了这段代码的行为?int*ptr=newint[10];operatordelete[](ptr,0);这段代码编译得很好,(在我的机器上)似乎什么也没发生。它的行为是否在某处定义? 最佳答案 在这个声明中operatordelete[](ptr,0);显式调用了释放函数voidoperatordelete[](void*,std::size_t)noexcept;调用中类型为size_t的第二个参数刚设置为0。当分配的内存大小不等于0时,第二个参数等于0的调用行为是未定义的。

c++ - 为什么不能使用 'link' 作为类名

如标题所述。以下代码显示错误:#includeusingnamespacestd;classlink{public:link(){num=0;next=NULL;}intnum;link*next;};intmain(){linktest;return0;}用编译这段代码g++test.cpp-otest我的g++版本是g++(Ubuntu/Linaro4.6.3-1ubuntu5)4.6.3编译器显示如下错误test.cpp:Infunction‘intmain()’:test.cpp:18:10:error:expected‘;’before‘test’如果我评论这个“链接测试”声

c++ - 重复符号链接(symbolic link)器错误(C++ 帮助)

我现在正在学习一些CSP(约束满足)理论,并且正在使用this解析XML文件的库。我将Xcode用作IDE。我的程序编译正常,但当它链接文件时,我收到XMLParser_libxml2.hh文件的重复符号错误。我的文件是这样分开的:包含上述XMLParser文件的类头文件包含类头文件的类实现文件包含类头文件的主文件重复符号出现在main.o和classfile.o中,但据我所知,我实际上并没有两次添加该.hh文件。完整错误:ld:duplicatesymbolboolCSPXMLParser::UTF8String::to,std::allocator>>(std::basic_str

c++ - 在派生类中重写运算符 new/delete

我有一个无状态的抽象基类,各种具体类都从中继承。其中一些派生类也是无状态的。因为它们中的许多是在运行期间创建的,所以我想通过覆盖运算符new()/delete()让所有无状态派生类模拟单例来节省内存和开销。一个简化的例子看起来像这样:#includestructBase{virtual~Base(){}protected:Base(){}//preventconcreteBaseobjects};structD1:publicBase{//statefulobject--defaultbehaviorintdummy;};structD2:publicBase{//statelesso

c++ - 显式删除析构函数而不调用 delete

我正在阅读C++11FAQ并注意到这一点:classX4{~X4()=delete;//Disallowdestruction}ThisimplicitlyalsodisallowsmovingofX4s.Copyingisallowed,butdeprecated.我还找到了thisquote.Deletingthedefinitionofadestructorwillrequireallocationonthefree-storebecausestaticandautomaticobjectsimplicitlyinvokethedestructor:`structC{~C()=d

c++ - 什么时候调用 __cxa_deleted_virtual

我尝试为avrc++构建构建一个小测试用例集。通常从c++库中提供一些“异常函数”。现在我想编写一个测试程序来生成必须链接到__cxa_deleted_virtual的错误代码。任何人都可以提供导致链接到该函数的代码片段吗?我实际上不知道如何生成这个“有问题”的代码。 最佳答案 用于填充已定义为已删除的虚函数的虚表槽:structB{virtualvoidf()=delete;};structD:B{virtualvoidf()=delete;};(被删除的虚函数包含在vtable中的原因是thisallowsittobelater