草庐IT

GUARD_BAND_SIZE_BYTES

全部标签

ruby-on-rails - Rails guard 内存不足

我是Rails开发的新手,但我对guard有很大的疑问。我正在使用guard自动测试我的应用程序,但我不断收到以下错误消息[FATAL]failedtoallocatememory有人知道是什么原因造成的吗?我在Windows7x64机器上使用Ruby1.9.3和最新版本的guard。[编辑]在我删除wdmgem之后,似乎不再出现此错误。有什么想法吗? 最佳答案 我想出了答案,它被覆盖了here. 关于ruby-on-rails-Railsguard内存不足,我们在StackOverfl

windows - 在 Windows 中设置 ES_HEAP_SIZE

我使用的是Windows2012R2机器。我在环境变量中设置了我的堆大小如下ES_HEAP_SIZE4克设置堆大小后,我使用命令将Elasticsearch安装为Windows服务service.batinstall当我启动该服务时,Elasticsearch服务已正确占用4GB(已在Taskmanger.exe中查看)一段时间后,elasticsearch服务使用的内存下降到1GB。这是预期的吗? 最佳答案 这显然是anissueofESunderWindows.引用自链接:The4gbcommittedheapsizethaty

windows - 在 Windows 7 Process Explorer 中,什么是 "VM Size"的等价物?

在任务管理器的进程资源管理器中,曾经有一个叫做“VMSize”的东西,它表示应用程序使用的不常用交换磁盘空间的数量。在Windows7进程资源管理器中,它似乎不存在。我想知道等效项是“私有(private)字节”还是“分页数据”。有什么想法吗?编辑:我知道VM是什么。只需要知道Windows7中等效的进程资源管理器列名称是什么。 最佳答案 我很确定您对工作集值感兴趣。据我了解,工作集是分配给您的应用程序并由您的应用程序引用的完整虚拟内存页面集。PrivateBytes值告诉您当前在私有(private)堆上(例如通过malloc()

windows - 为什么editbin/swaprun :CD/swaprun:NET change two bytes?

使用选项/swaprun:CD和/swaprun:NET为dll调用editbin会更改dll的PEheader字,设置位$0400和$0800(因此实际上它只更改高字节)。这就是它应该做的。但它也改变了另一个字节(见十六进制比较)。任何人都可以向我解释这个字节的含义以及为什么要更改它吗?编辑:澄清:具有这些选项的editbin应该设置PEheader的特征字段(这是一个16位字)中的IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP和IMAGE_FILE_NET_RUN_FROM_SWAP位。这是我说的第一个字节。这些标志都没有存储在第二个字节中,那么为什么该工具会

c - 提前以编程方式确定文件 "size on disk"

在写入之前,我需要知道给定的内存缓冲区作为磁盘(U盘)文件有多大。我知道除非大小落在block大小边界上,否则它可能会被四舍五入,例如一个1字节的文件在磁盘上占用4096字节。我目前正在使用GetDiskFreeSpace()来计算磁盘block大小,然后使用它来计算磁盘大小,如下所示:GetDiskFreeSpace(szDrive,&dwSectorsPerCluster,&dwBytesPerSector,NULL,NULL);dwBlockSize=dwSectorsPerCuster*dwBytesPerSector;if(dwInMemorySize%dwBlockSize

c++ - size_t 和 SIZE_T : is there any point to care?

有什么理由不假设SIZE_T是Microsoft的VisualC/C++编译器上size_t的类型定义?Windowsintsafe.h函数确实包括从一个函数到另一个函数的安全转换函数。这仅仅是为了完整性,还是存在静态转换可能无法给出预期结果的任何情况? 最佳答案 如果您的应用程序必须是跨平台的,那么您将只能使用语言中的标准内容,即std::size_t。否则,使用看起来合适的东西。如果您的目标是获得std::size_t类型,那么为什么不直接使用它而不关心平台特定类型呢?顺便说一句,std::size_t保证为最大数组大小提供足够

windows - windbg !heap 输出中的 'size' 数字是什么意思?

我在我的DMP文件中看到这样的输出:HeapentriesforSegment00inHeap0015000000150640:00640.00040[01]-busy(40)00150680:00040.01808[01]-busy(1800)00151e88:01808.00210[01]-busy(208)00152098:00210.00228[00]001522c0:00228.00030[01]-busy(22)001522f0:00030.00018[01]-busy(10)00152308:00018.00048[01]-busy(3c)WinDbg文档是这样说的:He

windows - 为什么无法从具有 PAGE_GUARD 保护的 block 中读取数据?

我使用ReadProcessMemory函数从地址空间读取数据。我尝试读取所有具有MEM_PRIVATE类型的block。但是当那个block有PAGE_GUARD保护时我得到错误(函数返回0),为什么?感谢大家。 最佳答案 具有PAGE_GUARD保护的页面保证不可访问。对它的任何访问都会产生页面错误,并作为STATUS_GUARD_PAGE_VIOLATION异常反射回拥有该页面的进程。此功能在Windows中大量使用,以检测此站点的命名条件并从中恢复。线程堆栈的最后两页是保护页。当程序递归地崩溃,消耗所有堆栈空间并触发异常时,

c++ - 带有 PAGE_GUARD 的 VirtualProtect 不使用局部变量

这按预期工作。引发了STATUS_GUARD_PAGE_VIOLATION。intmain(){DWORDoldp;DWORD*pdp=newDWORD;*pdp=0;if(!VirtualProtect(pdp,sizeof(DWORD),PAGE_READWRITE|PAGE_GUARD,&oldp))return1;*pdp=1000;return0;}然而,当运行这段几乎相同的代码时,程序无一异常(exception)地退出。intmain(){DWORDoldp;DWORDpd=0;DWORD*pdp=&pd;if(!VirtualProtect(pdp,sizeof(DWO

c++ - Private Bytes >> Working Set 是否正常?

好吧,这可能听起来很奇怪,但就是这样。有2台计算机,A(奔腾D)和B(四核),运行WindowsXP的RAM数量几乎相同。如果我在两台计算机上运行相同的代码,A中分配的私有(private)字节永远不会下降,从而导致以后的崩溃。在B中,私有(private)字节似乎不断被释放,一切看起来都很好。在两台计算机中,工作集的释放和分配方式类似。这可能是list或DLL(系统)的问题吗?我一无所知。此外,我在A上编译了可执行文件并在B上运行它,它成功了。备注:我用ProcessExplorer观察了使用的内存.问题:在执行期间(我们有多个分配和解除分配)私有(private)字节数远比工作集?