草庐IT

checked_delete

全部标签

c++ - Valgrind 报告不匹配的 free()/delete/delete []

我正在编写一个可以在多个系统上运行的库(其中一些没有malloc或stdlib)。在我的标准库(不同的库)中,我覆盖了new和delete运算符以对函数进行通用调用(此示例没有这些函数)。每个系统都会将这些通用调用覆盖到它们各自的内存分配设备。问题是当我尝试这样做时。下面是一些精简的示例代码来重现该问题:#includevoid*operatornew(unsignedlongsize){returnstd::malloc(size);//wouldnormallycallanintermediatefunctionwhichwouldbeoverriddenbythesystem}v

c++ - C++ 标准中哪里说::delete 可以更改左值?

我遇到了我的第一个编译器,它更改了传递给::delete的左值,但没有将左值清零。以下是正确的:Foo*p=newFoo();Foo*q=p;assert(p!=0);assert(p==q);::deletep;assert(p!=q);assert(p!=0);请注意,删除操作后p不为零,它已从旧值改变。一位同事告诉我,根据他使用一些大型机C++编译器将p更改为0xFFFFFFFF以及将p更改为0的其他编译器的经验,这并不罕见。在C++标准中哪里说允许编译器这样做?通过StackOverflow搜索,我发现了这个问题:Whydoesn’tdeletesetthepointertoN

C++ vector::_M_range_check 错误?

这是我的功能:voidloadfromfile(stringfn,vector&file){intx=0;ifstreamtext(fn.c_str());while(text.good()){getline(text,file.at(x));x++;}//cout我传入的fn的值只是一个文本文件的名称('10a.txt')我传入的文件的值声明如下:vectorfile1;我没有定义大小的原因是因为我不认为我必须使用vector,它们是动态的……不是吗?此函数应该读取给定的文本文件并将每行的全部内容存储到单个vector单元格中。例。将第一行的内容存入file.at(0)将第二行内容存

c++ - 如果我为一个类写new和delete运算符,我是否必须写所有它们的重载?

C++引用页列出了globalnewoperators的8种特定于类的重载。其中有四个是为2017版的C++添加的。类特定的分配函数void*T::operatornew(std::size_tcount);void*T::operatornew[](std::size_tcount);void*T::operatornew(std::size_tcount,std::align_val_tal);//(sinceC++17)void*T::operatornew[](std::size_tcount,std::align_val_tal);//(sinceC++17)特定于类别的展示

C++:如果我重载 new 运算符,我是否也必须重载 delete 运算符?

我正在阅读关于SO和answers中的一个问题,它被提到为:Ifnounambiguousmatchingdeallocationfunctioncanbefound,propagatingtheexceptiondoesnotcausetheobject’smemorytobefreed.因此,如果我只是重载我的new运算符而不是delete运算符,是否会创建和调用任何默认的delete运算符;或者,我是否还必须显式编写delete运算符。 最佳答案 这意味着如果你用额外的参数重载operatornew,而不是用额外的参数重载相应

c++ - 如何在多线程程序中定位 Valgrind 报告的 free/delete 不匹配?

这是Valgring报告:==14546==Thread5:==14546==Invalidfree()/delete/delete[]==14546==at0x490555D:free(vg_replace_malloc.c:235)==14546==by0x3BF7EFAA8F:free_mem(in/lib64/tls/libc-2.3.4.so)==14546==by0x3BF7EFA581:__libc_freeres(in/lib64/tls/libc-2.3.4.so)==14546==by0x4802676:_vgw_freeres(vg_preloaded.c:62)

c++ - BOOST_CHECK_NO_THROW 如何打印异常信息

当我测试一个方法时使用BOOST_CHECK_NO_THROW(method_to_test());并且抛出一个异常,它显示一个异常被抛出,但从来没有像这样的异常消息:test.cpp(14):errorin"test":incorrectexceptionmy_exceptioniscaught是否也可以打印异常消息,即my_exception.what()返回的字符串?my_exception派生自std::exception并重载what()。 最佳答案 我发现自己对BOOST_REQUIRE_NO_THROW的同样问题感到恼

C++ 语法 : default and delete modifiers

今天我偶然发现了这样一个代码片段:classA{A()=default;A(constA&)=delete;...}我从未见过delete或default关键字。它们是C++11标准的一部分吗?它们的用途是什么? 最佳答案 现在可以默认或删除特殊成员函数。已删除的成员函数仍然参与重载决议,但如果它被选中,则程序格式错误并且编译停止并提供有用的诊断。这是编写不可复制类之类内容的正确方法,并且用户会收到正确的错误消息。默认成员函数“做它应该做的”,例如默认的默认构造函数默认初始化所有基类和成员,并且主体为空;默认复制构造函数复制每个基对

【C++】:内存管理:C++内存分布 || C++中动态内存管理(new || delete)

📭1.C/C++内存分布【说明】🃏1.栈又叫堆栈–非静态局部变量/函数参数/返回值等等,栈是向下增长的🃏2.内存映射段是高效的I/O映射方式,用于装载一个共享的动态内存库。用户可使用系统接口创建共享共享内存,做进程间通信。(Linux课程如果没学到这块,现在只需要了解一下)🃏3.堆用于程序运行时动态内存分配,堆是可以上增长的。🃏4.数据段–存储全局数据和静态数据。🃏5.代码段–可执行的代码/只读常量我们先来看下面的一段代码和相关问题intglobalVar=1;staticintstaticGlobalVar=1;voidTest(){staticintstaticVar=1;intlocal