草庐IT

memory-leak-detector

全部标签

c++ - memory_order_acquire 真的足以锁定自旋锁吗?

根据AntonyWilliams的书C++ConcurrencyinAction,自旋锁可以按如下方式实现:classspinlock_mutex{std::atomic_flagflag;public:spinlock_mutex():flag(ATOMIC_FLAG_INIT){}voidlock(){while(flag.test_and_set(std::memory_order_acquire));}voidunlock(){flag.clear(std::memory_order_release);}};如果我没理解错的话,memory_order_acquire标签确保了

c++ - delete p where p is a pointer to array always a memory leak?

在一次软件session上的讨论之后,我着手确定使用普通delete删除动态分配的基元数组是否会导致内存泄漏。我已经编写了这个小程序并使用在WindowsXP上运行的visualstudio2008对其进行了编译:#include"stdafx.h"#include"Windows.h"constunsignedlongBLOCK_SIZE=1024*100000;int_tmain(){for(unsignedinti=0;i然后我使用任务管理器监视我的应用程序的内存消耗,令人惊讶的是内存被正确分配和释放,分配的内存没有像预期的那样稳定增加我修改了我的测试程序以分配一个非基本类型数组

c++ - 在 Qt Creator 中使用 'Analyze Memory' 工具

我正在使用QtCreator开发C++应用程序,我正在尝试追踪一些内存泄漏。我关注了theseinstructions*,并在我的Ubuntu机器上安装了Valgrind。我从AnalyzeMemory部分开始我的应用程序,在单击停止按钮后,我被告知ToolAnalyzeMemory已完成,发现928个问题。但是,分析部分没有显示任何结果,该部分仍为空白。我做错了什么吗?在哪里可以找到内存分析的结果?*令人困惑的是,说明要求“发布”构建配置,但选择此选项会导致Qt中出现警告,指出内存分析工具需要调试配置。两种方法我都试过了。 最佳答案

c++ - C++ 示例 "Memory barrier"

这个问题在这里已经有了答案:C++MemoryBarriersforAtomics(2个答案)关闭9年前。我正在阅读这个关于volatile关键字的问题的答案:https://stackoverflow.com/a/2485177/997112那个人说:Thesolutiontopreventingreorderingistouseamemorybarrier,whichindicatesbothtothecompilerandtheCPUthatnomemoryaccessmaybereorderedacrossthispoint.Placingsuchbarriersaroundo

c++ - 使用/不使用 Visual Leak Detector 在 C++ 中检测内存泄漏

我想在Windows中检测我的C++程序的内存泄漏。我也在MSDN上阅读了关于的文档mermoyleakdetection我也开始使用VisualLeakDetector。我对泄漏的报告有疑问。我期待一个带有行号的文件名,但我总是报告下面的文本。它具有泄漏描述的所有组件(块类型、内存地址、数据等。)除了文件名和行号。如果是真的泄漏?如果是,您知道为什么没有报告文件/行吗?同时我也在看thisurl谢谢检测到内存泄漏!转储对象->{4723}位于0x04AFB5B8的普通块,8字节长。数据:2C3F0000283F0000{1476}位于0x04AC3B58的普通块,12字节长。数据:0

c++ - boost::interprocess::managed_shared_memory 在不同版本的 boost 之间的兼容性

是否有明确的兼容性保证boost::interprocess::managed_shared_memory可以跨不同的boost版本工作?我打算用它在多个进程之间共享一个整数或十(这实际上将充当它们都读取和写入的一段数据的修订号)。这些进程是单独发布的,并且偶尔会终止使用。问题是:我是否会因为1.51中的managed_shared_memory无法与1.44中的managed_shared_memory进行对话而将自己永远锁定在给定的boost版本上? 最佳答案 根据BoostFAQ:HowcantheBoostlibraries

c++ - 如何调试或修复涉及 boost::interprocess managed_shared_memory 的无限循环和堆损坏问题?

我收到以下“第一次机会异常”消息,该消息来self编写的DLL,该DLL在我未编写的可执行文件中运行。也就是说,DLL是一个插件。第一次触发此异常时,尝试打开共享内存映射文件失败。如果我忽略第一次机会异常而只是运行,应用程序最终会卡住或崩溃。First-chanceexceptionat0x76a7c41finnotmyexe.exe:MicrosoftC++exception:boost::interprocess::interprocess_exceptionatmemorylocation0x002bc644..几个小时后,它似乎是由一段无限循环的代码块引起的,直到预期的异常条件

c++ - 基本 Qt 应用程序 : Reports Masive Leaks 上的 Valgrind

所以我想看看当通过Valgrind运行时,从简单的Makefile编译的基本Qt4应用程序会发生什么。什么会导致这些泄漏?我正在删除我这边的任何动态分配的对象。另外,退出程序时,我只单击右上角的关闭(X)。GUI库是否只是“free()”它们malloc()的任何内存?由qmake命令缩减的Makefile是:#######Compiler,toolsandoptionsCXX=g++CXXFLAGS=-pipe-O2-Wall-WLIBS_INCLUDE=${HOME}INCPATH=-I$(LIBS_INCLUDE)/QtSDK/Desktop/Qt/473/gcc/mkspecs

带有栅栏和获取/释放的 C++ memory_order

我有以下C++2011代码:std::atomicx,y;std::atomicz;voidf(){x.store(true,std::memory_order_relaxed);std::atomic_thread_fence(std::memory_order_release);y.store(true,std::memory_order_relaxed);}voidg(){while(!y.load(std::memory_order_relaxed)){}std::atomic_thread_fence(std::memory_order_acquire);if(x.load(

c++ - 为什么 RegisterClass 因 ERROR_NOT_ENOUGH_MEMORY 而失败?

很快,我的问题是,当有大量可用内存时,为什么WinAPIRegisterClass会失败并返回ERROR_NOT_ENOUGH_MEMORY,我该怎么做才能防止它发生?背景:我正在开发一个应用程序(WinSCPFTP/SFTP客户端),许多人使用它来自动传输文件。有些人每天每分钟都在通过Windows调度程序运行它。我收到很多报告,在运行一定次数后应用程序停止工作。触发问题的运行次数似乎并不准确,但在几万到几十万之间。此外,问题似乎仅在Windows调度程序下运行时出现,而不是在常规Windowssession中运行时出现。虽然我不能100%证实这一点。此外,所有报告似乎都针对Wind