草庐IT

延时分配

全部标签

windows - 服务启动的进程无法分配内存

我有一个作为LocalSystem帐户运行的C#服务,它根据需要启动许多其他进程。这几个月一直很好。就在本周,一些子流程崩溃了。我已将远程调试器附加到它们,但它们在内存分配方面失败(C++new运算符返回0x0),这是崩溃的间接原因。有趣的是,如果我将RDP接入机器,我可以轻松地从CMD启动进程,没有任何问题。然而,当服务启动它时,不行。机器运行的是WindowsXPSP3。这不是因为提交费用大约是物理RAM的80%。服务可以使用多少进程或多少内存有一些特殊限制,包括该服务产生的进程?为什么这些进程无法分配内存的任何其他想法。编辑:我已经仔细查看了SysInternals的Procmo

c++ - 指向动态分配数组的静态指针

所以这个问题比较直截了当,我有几个半大型查找表~500kb一张。现在,这些完全相同的表被几个类实例化(可能很多)使用,考虑到这一点,我不想在每个类中存储相同的表。所以我可以将整个表作为“静态”成员转储到堆栈中,或者我可以有指向这些表的“静态”指针。在任何一种情况下,该类的构造函数都会检查它们是否已初始化,如果没有则进行初始化。但是,我的问题是,如果我选择指向表的静态指针(以免滥用堆栈空间),什么是适当清理这些表的好方法。另请注意,我考虑过使用boost::share_ptr,但选择不使用,这是一个非常小的项目,我不打算添加任何依赖项。谢谢 最佳答案

windows - 获取正在运行的进程的分配内存区域

谁能告诉我如何使用WinAPI函数获取某些进程的内存分配内存区域?我想知道每个区域、起始地址、大小和其他一些信息,例如保护类型等。我找不到任何WinAPI函数来执行此操作;-(谁能帮帮我? 最佳答案 有代码可以使用VirtualQueryEx来暴力破解here:MEMORY_BASIC_INFORMATIONmbi;/*Getmaximumaddressrangefromsysteminfo*/GetSystemInfo(&si);/*walkprocessaddresses*/lpMem=0;while(lpMemmbi.Base

c++ - wcsdup 分配的内存是否应该显式释放?

类似wcsdup的函数,隐式调用malloc为目标缓冲区分配内存。我想知道因为内存分配不是很明确,所以显式释放存储似乎合乎逻辑吗?这更像是一个设计困境,赞成和反对的理由如下应该被释放因为不释放它会导致内存泄漏。有据可查的是,wcsdup/_wcsdup调用malloc来分配内存,即使它是从C++程序调用的。不应被释放,因为wcsdup积累的内存最终会在程序退出时释放。在整个程序生命周期中,我们总是会遇到一些内存泄漏(除非我们大量调用wcsdup以获得较大的缓冲区大小)。它可能会造成混淆,因为free之前没有明确的malloc。由于它不是标准的一部分但符合posix,Microsoft实

c++ - 是否有可能获得由 'new' 分配的内存块大小?

你好,我需要记录我的堆,但现在我只想用我的函数重载"new"运算符。我需要总结在malloc()或Heap*()或其他windowsmem*函数之后增加的内存的实际字节数但现在我需要分析当前的堆实现。是否有可能获得像HeapAlloc()函数分配的block大小-HeapSize()?. 最佳答案 我看你没有搜索文档。HeapSize()exists.编辑回想起来,也许您正在寻求HeapSize()的替代方案,您可以在使用新。答案是否定的。标准分配例程没有任何关于内存块的信息,因为:这高度依赖于实现,并且您已经知道block大小(因

c++ - 奇怪的 malloc 行为不允许在 64 位进程上分配超过 2GB 的内存

这个问题涉及我正在开发的一个程序。我从事的项目要求不通过网络发送行集或大于2GB的行(网络不能发送大于2GB的数据组)。我已经对代码进行了所有适当的更改,因此它不会发送这个/这些组,但现在我正在尝试构建测试用例。我已经构建了一个测试,它创建了不到10亿行,这些行占用了超过2GB的空间。在通过网络发送这些行之前,程序会正确地过滤掉它们。我遇到的问题是我需要创建一个单独的行来保存一个包含单个字符串的列或列的集合,在该行内,保存字符串,其中该行的大小大于2GB。但是当字符串开始占用接近2GB时,malloc返回NULL。我做了一些研究,发现可能是我没有足够的连续内存,所以我开始添加更多带有较

c++ - Windows 堆分配调用堆栈 - 奇怪的调用堆栈

我正在尝试分析托管进程内存转储,怀疑是否存在native内存泄漏。为了能够使用windbg(并从那里使用!heap扩展),我为服务器进程激活了用户模式调用堆栈我看到很多大小为68的block。在这些block中(我可以使用!heap-p-a手动验证的block)有许多调用堆栈的形式!heap-p-a000000003ca5cfd0address000000003ca5cfd0foundin_HEAP@1ea0000HEAP_ENTRYSizePrevFlagsUserPtrUserSize-state000000003ca5cfa000090000[00]000000003ca5cfd

windows - Windows 7 格式化驱动器上的 FAT32 文件分配表大小超出 FAT32 规范

我正在编写一个嵌入式FAT32驱动程序。我有问题。我用零填充我的金士顿DTR30G2高达1GB,并将其插入Windows7盒子,并将其格式化为FAT32。然后,在我的Linux机器上,我将1GB的闪存转储到文件中并在十六进制编辑器中打开它并获得以下值:uint16_tBPB_ResvdSecCnt=32atoffset0xEuint8_tBPB_SecPerClus=8atoffset0xDuint8_tBPB_NumFATs=2atoffset0x10接下来,我查看FAT32卷ID中的扇区总数:uint32_tDskSize=30734336atoffset0x20和Linux报告一

Python检测USB驱动器然后分配驱动器号?

问题来了。我们有数百个外部500gbUSB驱动器。在这一年中,每次驾车都会前往一个新的地点。自动检测USB驱动器已插入Windows系统,然后分配Z:\盘符的最佳方法是什么?这些USB驱动器将插入许多不同的计算机,因此像这样的脚本importsubprocessdiskpart_data="z-drive.txt"open(diskpart_data,"w").write("""selectvolumeF:assignletter=Z""")subprocess.call('diskpart/s%s'%diskpart_data)由于移动USB驱动器始终在不同Windows系统上的动态

c++ - 如何强制 C++ 从磁盘分配内存?

我有数千行C++代码,这些代码在小文本文件上运行良好,但在大文本文件(例如2GB大小)上会崩溃。崩溃原因:应用占用内存。是否可以从磁盘分配内存?因为在大多数情况下,硬盘空间远大于物理内存。如果我可以从硬盘为我的应用程序借用一些空间并在使用后将它们归还,那么我的应用程序崩溃的可能性很小。以下是我的设计思路:为文件映射创建临时文件(CreateFileMapping,OpenFileMapping)强制我的应用从临时文件分配内存做一些清理工作:CloseFileMapping并删除临时文件因为我现有的代码太多,如果我的设计思路合理,我不想重新设计我的项目。我不确定这个设计思想是否可以实现。