草庐IT

虚拟内存分区

全部标签

C语言进阶——动态内存管理(上)

🌇个人主页:_麦麦_📚今日名言:“你若爱,生活哪里都可爱。你若恨,生活哪里都可恨。你若感恩,处处可感恩。你若成长,事事可成长。不是世界选择了你,是你选择了这个世界。既然无处可躲,不如傻乐。既然无处可逃,不如喜悦。既然没有净土,不如静心。既然没有如愿,不如释然。”                                                      ——丰子恺《豁然开朗》目录​编辑一、前言二、正文        1.内存的分布        2.为什么存在动态内存开辟        3.动态内存函数的介绍                 3.1malloc          

xml - 适用于 .net/PowerShell 的良好内存数据库?

如果我有一个脚本来处理可以存储在变量中的稍微复杂一点的状态信息,那么小型内存数据库的最佳选择是什么?Sqlite是一个选项,尽管那将是一个外部依赖项。XML或许可以,尽管它是非关系型的。对于这项工作的工具是否达成共识? 最佳答案 考虑到PowerShell对.NET脚本的强大支持,使用ADO.NET怎么样?DataSet. 关于xml-适用于.net/PowerShell的良好内存数据库?,我们在StackOverflow上找到一个类似的问题: https:/

windows - UMDH 日志(Windows 上的内存泄漏)

我正在使用UMDH工具来分析我的应用程序的内存泄漏。UMDH日志观察到的主要泄漏如下:237856226(241016812-3160586)3704833分配BackTraceE93685198(3704833-19635)BackTraceE9分配ntdll!RtlIpv4StringToAddressExW+00011866ntdll!RtlSubAuthorityCountSid+00000019MSVCR80!malloc+0000007A207093760(207355904-262144)791allocsBackTrace6EB790(791-1)个BackTrace6

Windows 保护模式 - 内存

我下载了一个名为HxD的磁盘和内存编辑器(可在http://mh-nexus.de/en/hxd/获得)。我想知道它如何能够访问(读取和修改)分配给我系统(WindowsXPProSP3)上运行的所有应用程序的虚拟内存。据我所知,Windows正在保护模式下运行,因此无法进行此类尝试。又不是,怎么可能呢? 最佳答案 Windows确实保护了应用程序的内存。每个应用程序都有自己的地址空间,并且无法访问它之外的任何内容。但是,Windows也有允许您从其他进程访问内存的功能。不是通过简单地访问指针,而是通过调用函数从其他进程获取数据。这

c# - 运行 Windows 服务以观察服务运行增长内存(泄漏)

我已经检查了这里的所有帖子,但到目前为止找不到适合我的解决方案。我确实设置了一个小服务,它应该只监视我要监视的其他服务是否运行,如果没有运行,则重新启动它并在应用程序事件日志中放置一条消息。该服务本身运行良好,没什么特别的:),但是当我启动该服务时,它使用大约1.6MB的RAM,并且每10秒它增长60-70k,这足以忍受它。我尝试处理并清除所有资源。尝试使用System.Timers而不是实际的解决方案,但没有任何效果如我所愿,内存仍在增长。调试或发布版本没有区别,我在.Net2上使用它,不知道它对你3、3.5或4是否有影响。有什么提示吗?!usingSystem;usingSyste

java - 为什么 Glassfish 在 Linux 中似乎比在 Windows 中需要更多内存?

我最近一直在修补GlassFish2.1.1,既有UbuntuLinux机器,也有WindowsXP机器。查看Windows上代表asadmin、JavaDB服务器和GlassFish应用程序服务器域本身的“java”进程(使用任务管理器),它们加起来刚好超过100MB的内存。但是,查看Linux机器上的相同进程(使用“psaux”和Gnome系统监视器)显示内存使用量大约为800MB。这对我来说似乎非常奇怪。如果有的话,我会假设Windows上的内存使用不太有利。无论哪种方式,我都不会期望两者之间的Swing如此戏剧化。我在这里缺少一些基本的东西吗?我不一定需要详细的分析信息,我只需

windows - 是什么导致磁盘上的驱动程序和映射到内存的驱动程序之间存在差异?

嘿,今天我尝试对NDIS.sys进行二进制比较,我发现了一些奇怪的东西。我接受了一个函数,并开始比较它。前30个字节在磁盘(使用IDA)和内存(使用WinDbg)上是相同的。然后,事情发生了变化。我看到类似“jmp_imp_XXXXX”的内容。JMP字节相同,但地址不同。我的问题是-是什么造成了差异?我认为这与搬迁有关。虽然跳转是在同一个模块中寻址,但它是一个长跳转,它相对于模块基地址。如果发生重定位,它也需要重定位这个地址,尽管它在同一个模块上。我是对还是完全错了?:-)谢谢。 最佳答案 是的,当一个模块没有加载到它在内存中的首选

C# 从 Windows 写入 ext2 linux 分区

我是C#的新手,我需要在Windows7的EXt2linux分区上写一个文件(grub)。做这种事情的好方法是什么?我需要用外部程序挂载分区吗? 最佳答案 我认为您需要使用外部程序安装它,例如:http://www.fs-driver.org/ 关于C#从Windows写入ext2linux分区,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4197159/

windows - 识别内存映射文件

我正在使用VirtualQuery识别部分进程的虚拟内存。我确定了映射文件(MEM_MAPPED)占用的区域,但是如何确定分配在那里的文件的实际文件(文件名)?我想它与MapView*API系列有关,但无法准确地弄清楚... 最佳答案 看起来GetMappedFileName()是您想要的函数。DWORDWINAPIGetMappedFileName(__inHANDLEhProcess,__inLPVOIDlpv,__outLPTSTRlpFilename,__inDWORDnSize);GetMappedFileNameonMS

windows - 内核内存地址空间

我读到过,在具有4GB系统内存的32位系统上,2GB分配给用户模式,2GB分配给内核模式。但是,如果我有一个具有512MB内存的系统,它会被划分为256MB给用户地址空间和256MB给内核地址空间吗? 最佳答案 您混淆了物理内存和虚拟内存。2GB分配给用户/系统,但它是虚拟内存。更正确的说法是它们不是分配的,而是构成了一个寻址空间。最初这个空间根本没有绑定(bind)到物理内存。当应用程序实际需要内存时(第一次是在启动时)分配物理内存并将地址空间中的一些地址映射到它。当内存被分配但使用时间不够长或PC的物理内存用完时,数据可以转储到