我的应用程序需要大量内存和大数据结构才能执行其工作.
应用程序通常需要超过1 GB的内存,在某些情况下,我的客户确实需要使用64位版本的应用程序,因为它们有几GB的内存.

在过去,我可以很容易地向用户解释,如果内存达到1.6到1.7 GB的内存使用量,那就是“内存不足”或者真的接近“内存不足”的情况,他们需要减少内存或者转移到64位版本.

去年我注意到,应用程序通常在内存耗尽之前仅使用大约1 GB.经过一些调查后,似乎这个问题的原因是内存碎片化.我使用VMMAP(一个SysInternals实用程序)来查看我的应用程序的内存使用情况,看到如下所示:

橙色区域是我的应用程序分配的内存.紫色区域是可执行代码.

正如您在图像的下半部分所看到的那样,紫色区域(它们是DLL)被加载到许多不同的地址,导致我的内存碎片化.如果我的客户没有大量数据,但如果我的客户的数据集超过1 GB,并且部分应用程序需要大块内存(例如50 MB),这不是一个真正的问题,它可能导致内存分配失败,导致我的应用程序崩溃.

我的大多数数据结构都是基于STL的,并且通常不需要大块的连续内存,但在某些情况下(例如非常大的字符串),确实需要有一个连续的内存块.不幸的是,并不总是可以更改代码,因此它不需要这样一个连续的内存块.

问题是:

>如何在不在客户计算机上的所有DLL上明确使用REBASE,或者不显式加载所有DLL的情况下,如何影响DLL在内存中加载的位置.
>有没有办法在您自己的应用程序清单文件中指定DLL的加载地址?
>或者有没有办法告诉Windows(通过清单文件?)不散布DLL(我认为这种散射称为ASLR).

当然,最好的解决方案是我可以在应用程序的清单文件中影响的解决方案,因为我依赖于Windows自动/动态加载DLL.

我的应用程序是混合模式(托管非托管)应用程序,尽管应用程序的主要部分是不受管理的.

有人建议吗?

首先,虚拟地址空间碎片不一定会导致内存不足.如果您的应用程序必须分配适当大小的连续内存块,则会出现这种情况.否则,碎片的影响应该是微不足道的.

你说你的大多数数据是“基于STL的”,但是如果你分配一个巨大的std :: vector你需要一个连续的内存块.

AFAIK无法在加载时指定DLL的首选映射地址.所以只有两个选项:rebase it(DLL文件),或自己实现DLL加载(当然这不是一件小事).

通常,您不需要重新标记标准Windows API DLL,它们会非常紧密地加载到您的地址空间.碎片可能来自某些第三方DLL(例如Windows挂钩,防病毒注入等)

强制Windows在某些位置加载DLL,以便内存碎片最小化的更多相关文章

  1. 强制Windows在某些位置加载DLL,以便内存碎片最小化

    >或者有没有办法告诉Windows(通过清单文件?)不散布DLL.当然,最好的解决方案是我可以在应用程序的清单文件中影响的解决方案,因为我依赖于Windows自动/动态加载DLL.我的应用程序是混合模式应用程序,尽管应用程序的主要部分是不受管理的.有人建议吗?

  2. 为Windows开发人员构建开源库DLL的最佳方法是什么?

    在Linux上进行交叉编译?我更喜欢从SVN存储库中完全自动化的东西.我不认为cygwin是一个解决方案,因为这似乎没有提供Windows开发人员需要的东西,据我所知,问题–链接和DLL.您可以尝试使用MSYS的Mingw,使用SUA的VisualStudio或Cygwin来编译基于automake/autoconf的程序.不幸的是,他们创建的lib文件通常与其他编译器不兼容,因此如果您希望您的库使用使用VisualStudio开发的应用程序,那么您应该使用VSC方法.通常很多GNU项目实际上也有VC兼容

  3. .net – 在发布时突然没有复制引用的程序集(DLL)

    在Web项目发布期间,我遇到了一个引用库(ServiceStack.Ormlite)部署的奇怪问题.它工作正常,直到上周左右,现在突然一些ServiceStackDLL在项目从VisualStudio或msbuild发布到本地文件系统,FTP或WebDeploy时没有被复制.Ormlite引用通过nuget添加到类lib项目中.类lib项目引用被添加到主WebApp项目中.当我发布WebApp项目

  4. 我应该签署我的DLL吗?

    我有一个CWindows应用程序.我签署了我们的安装程序和我的可执行文件,但我目前没有签署我的DLL.签署这些也不是什么大不了的事,但有人可以解释一下这样做的好处吗?例如,如果所有依赖项都已签名,我的程序是否会与AV或防火墙软件有任何不同?

  5. 如何针对DLL劫持来检测我的.NET应用程序?

    我们有一个带注册扩展的.NET3.5应用程序.我们如何保护它免受DLL劫持攻击?

  6. .net – 在64位Win上缺少dll

    我有一个.net应用程序,它使用一些vc编译的Win32dll.它在32位Win上工作得很好,但在64位上存在一个问题:“无法加载DLL’xyz’:找不到指定的模块.”使用依赖walker我发现它错过了以下dll:MSVCP100.DLL,MSVCR100.DLL,GDIPLUS.DLL,GPSVC.DLL,IESHims.DLL如何将它们安装到我的64位Win?注意,我的项目是为x86平台编译的,它是从ProgramFiles文件夹作为32位应用程序运行的.我的dll在VisualStudio2010中

  7. 将本地化资源.DLL嵌入到C#中的可执行文件中?

    我想让我的程序多语言.我已成功通过Form的Localizable和Language属性使程序多语言化.它制作了一些.resx文件.然后我从.resx文件中删除了不需要的文件,例如图像(它们在所有语言中都是相同的)等.问题是,例如,它还生成一个名为“en”的文件夹,在该文件夹中,另一个生成的文件称为“ProjectName.resources.dll”.反正有没有将此资源文件嵌入.exe?将其添加

  8. 如何安装COM DLL的32位和64位版本并“自动选择”?

    我们有一个DLL,可以在32位和64位编译,但DLL使用相同的CLSID和AppID32位版本和64位版本.这可以,还是必须改变?它是一个C#应用程序,它包含对我们的COM服务器DLL的引用,如下所示:{C1FADEA6-68FD-4F43-9FC2-0BC451FA5D53}83000tlbimpFalse如果事实证明我们需要一个单独的64位CLSID,我们如何在VisualStudio中“仅针对32位配置”进行此引用?

  9. .net – DLL被标记为DELETEPENDING

    我在我的一个Windows机器上运行应用程序时遇到问题.我无法在其他类似的Windows机器上复制它,它刚刚开始发生.这是情况:>使用VisualStudio,我可以构建我编写的应用程序.它构建了一个可执行文件:Application.exe,我可以在其bin/Debug目录中看到这个可执行文件以及我知道该应用程序所依赖的所有DLL,包括Microsoft.Windows.Azure.Config

  10. 为什么我的WPF应用程序中出现“无法加载DLL’sqlite3’”?

    UPDATE我尝试了ajawad987的建议,但仍然得到相同的运行时错误,即使我有这个:…还有这个:更新2发生这个运行时异常的地方对我来说似乎很奇怪:如果SILVERLIGHT||USE_CSHARP_sqlITE其他万一但是我正在使用C#,那么为什么线路甚至无法运行呢?您的项目构建是否设置为任何cpu?自从我在.NET应用程序中使用sqlite以来已经有一段时间了.附注:您下载的Nuget包实际上只包含真正的sqliteDLL周围的C#包装器库.

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部