jjzjj

soft-delete

全部标签

c++ - 使用 protected 非虚拟析构函数时抑制 delete-non-virtual-dtor 警告

我有一个纯抽象接口(interface)类和一个实现该接口(interface)的派生类。structFoo{virtualvoiddoStuff()=0;};structBar:Foo{voiddoStuff()override{}};我的接口(interface)类没有虚拟析构函数。因此,尝试使用基类指针破坏派生实例显然是未定义的行为intmain(){Foo*f=newBar;f->doStuff();deletef;}幸运的是我的编译器足够聪明,可以捕捉到这个(使用-Werror)main.cc:15:9:error:deletingobjectofabstractclasst

c++ - 如何在编译器级别实现 `delete[] obj` 和 `delete obj`

这个问题在这里已经有了答案:关闭9年前。PossibleDuplicate:Why[]isusedindelete(delete[])tofreedynamicallyallocatedarray?WhydoesC++stillhaveadelete[]ANDadeleteoperator?我想知道它们有什么区别,我知道一些人可能会说的明显答案,一个是删除一个数组,另一个是删除一个对象,但我想知道为什么要有两种不同的删除方法这两个操作?我的意思是delete基本上是使用Cfree方法实现的,它不关心指针实际上是指向数组还是指向单个对象。我能想到的唯一原因是两个能够知道它是否是一个数组并

c++ - 基类中的唯一指针禁止实例化,错误为 "attempting to reference a deleted function"

我将我的C++工具链从VisualStudio2013更新到VisualStudio2017/2019。现在我遇到了一些形式的编译错误:(13):errorC2280:'OfflineFixture::OfflineFixture(constOfflineFixture&)':attemptingtoreferenceadeletedfunction(8):note:compilerhasgenerated'OfflineFixture::OfflineFixture'here(8):note:'OfflineFixture::OfflineFixture(constOfflineFi

c++ - 编译器错误 : ‘std::array<...>::~array()’ is implicitly deleted

我有以下.hpp文件:#ifndefCODE_HPP#defineCODE_HPP#include#includeusingstd::vector;usingstd::array;template>classstack;template,typenameK=stack>classstack_array;templateclassstack{Cpile;stack();~stack();voidpush(T&);friendclassstack_array>;};templateclassstack_array{private:staticconstsize_tmax_elem=10;a

[YOLOv7/YOLOv5系列算法改进NO.8]非极大值抑制NMS算法改进Soft-nms

​前  言:作为当前先进的深度学习目标检测算法YOLOv5,已经集合了大量的trick,但是还是有提高和改进的空间,针对具体应用场景下的检测难点,可以不同的改进方法。此后的系列文章,将重点对YOLOv5的如何改进进行详细的介绍,目的是为了给那些搞科研的同学需要创新点或者搞工程项目的朋友需要达到更好的效果提供自己的微薄帮助和参考。YOLOv7改进为soft-nms代码:链接:https://pan.baidu.com/s/1N9D5xjbhQjBoH12BxVsgsw 提取码:关注私信后获取解决问题:YOLOv5默认采用NMS算法,主要是通过IoU来筛选出候选框。NMS主要就是通过迭代的形式,不

c++ 调用 delete[] 导致崩溃

我正在分配一个数组,然后当我调用delete[]时它导致程序崩溃,当我不调用delete时程序运行正常。这是我的代码MyObject*myArray=newMyObject[numPoints];delete[]myArray;我非常困惑,所以任何帮助将不胜感激此外,当我调试时,我收到错误消息“检测到堆损坏:在0x000032E90处的正常block(#48)之后。CRT检测到应用程序在堆缓冲区结束后写入内存。”解决方案!:我在初始化数组时没有足够的空间。出于某种原因,我仍然可以向数组添加内容,但在调用析构函数时它会崩溃。 最佳答案

c++ - 如果重载了一个new但是没有加载对应的delete会怎样?

任何人都可以解释如果在C++中重载了new但未加载相应的delete会发生什么情况? 最佳答案 这只是对象构造抛出异常时的问题,在C++115.3.4/18中有描述:Ifnounambiguousmatchingdeallocationfunctioncanbefound,propagatingtheexceptiondoesnotcausetheobject’smemorytobefreed.[Note:Thisisappropriatewhenthecalledallocationfunctiondoesnotallocatem

c++ - 如何将具有 "deleted"复制构造函数和赋值运算符的类放入映射中?

因为我使用的是一个不完全是C++11的编译器(VS11),所以我收到一个关于防止使用复制构造函数和赋值运算符的链接器错误。一切都很好,但问题是我不能将我的类放在std::map中,其中键是uin32_t,值是我的类。我什至尝试了emplace,但它不起作用。我正在考虑std::move将unique_ptr放入map中,但不想重新设计容器。那么有没有什么优雅的方法可以做到这一点(优雅==不像在map中放置一个虚拟对象然后在值内存中放置新的:)?代码位是这样的:std::mapm_map;//declarednotdefinedpublic:LogFileWriter(constLogF

c++ - 在 C++ 中用 new/delete 替换 malloc/free

我只是想确定一下。这是我的代码int*Image=(int*)malloc(sizeof(int)*m_Width/2*m_Height);free(Image);如果我想使用new而不是malloc和free而不是delete。这是我写的int*Image=newint[m_Width/2*m_Height];delete[]Image;对吗? 最佳答案 从技术上讲,这是正确的。然而,这是我们正在谈论的C++,动态分配数组的C++方法是使用std:vector代替:std::vectorImage(m_Width/2*m_Heig

c++ - 所有 g++ 版本的 delete[] 可能存在错误或未定义此行为?

这个问题在这里已经有了答案:Whyisitundefinedbehaviortodelete[]anarrayofderivedobjectsviaabasepointer?(5个答案)关闭4年前。我有这段代码,它给了我3个或更多元素的段错误。我在vs和clang上测试并工作(循环结束和二进制结束没有错误)。我做错了什么?或者它是一个g++错误?如果我更改delete[]线到delete[]static_cast(a);它也适用于g++。但是,在实际情况下,我不知道真正的类型,所以我不能转换成任何东西。classA{public:virtual~A(){}virtualintx()=0