classA{publiceventEventHandlerAEvent;}classB{privateA_foo;privateint_bar;publicvoidAttachToAEvent(){_foo.AEvent+=delegate(){...UseBar(_bar);...}}}由于delegate捕获变量this._bar,它是否隐含地持有B的实例?B的实例是否会通过事件处理程序引用并由A的实例捕获变量?如果_bar是AttachToAEvent方法的局部变量,会有不同吗?因为在我的例子中,A的实例比B的实例生命周期长得多并且小得多,我担心会导致“内存泄漏”这样做。
编辑:我的问题没有得到我正在寻找的主要答案。我不清楚。我真的很想知道两件事:不能调用Dispose()会导致内存泄漏吗?如果您有一个大型程序并且从不对任何IDisposable对象调用Dispose(),那么最糟糕的事情是什么?我的印象是,如果未对IDisposable对象调用Dispose(),可能会发生内存泄漏。根据关于此thread的讨论,我的看法是不正确的;如果未调用Dispose(),则不会发生内存泄漏。那为什么还要调用Dispose()呢?是否只是立即释放资源,而不是稍后释放资源?如果您有一个大型程序并且从不对任何IDisposable对象调用Dispose(),那么最糟糕
例如,如果我有一个分层数据结构:classNode{publicListchildren;}它被填充到许多层次,然后在其中一个parent去:myNode.children.Clear();这将清除所有对直系子代的引用——但是那些直系子代引用的所有孙代、曾孙代等又如何呢?C#是否足够聪明,知道它们不再需要并且将被垃圾收集?我读过使用WPF数据绑定(bind)而不实现接口(interface)INotifyChanged会导致内存泄漏:http://blogs.msdn.com/b/micmcd/archive/2008/03/07/avoiding-a-wpf-memory-leak-
我有一个大型网站,似乎正在占用所有分配的内存。服务器上除此站点外没有其他任何内容。一周之内,它会耗尽2个演出并需要重新启动。目前这是使用IIS7的服务器200832位。我们正在重新安装以使用64位并添加更多内存。如果能够追踪泄漏发生的位置,那就太好了。那么跟踪内存泄漏的最佳实践是什么? 最佳答案 内存泄漏在.NET中并不常见,但当它们发生时,最常见的原因是未附加的事件处理程序。确保在监听器超出范围之前分离处理程序。另一种选择是,如果您忘记在IDisposable资源上调用Dispose()。这可能会阻止清理非托管资源(不由GC处理)
我有一个应用程序,由于在对象引用设置为null之前未分离事件而导致一些内存泄漏。应用程序很大,很难通过查看代码找到内存泄漏。我想使用sos.dll查找作为泄漏源的方法的名称,但我被卡住了。我建立了一个测试项目来演示这个问题。这里我有2个类,一个有一个事件,并且如下所示监听该事件namespaceMemoryLeak{classProgram{staticvoidMain(string[]args){TestMemoryLeaktestMemoryLeak=newTestMemoryLeak();while(!Console.ReadKey().Key.Equals('q')){}}}c
我的程序是一个CRM,我使用了RadRibbonBar、许多带图像的按钮、RadGridView(其中一些列包含图像)和许多其他包含图像的控件。这是一个mdi父/子程序。在许多情况下,当加载一个mdi子项或使用一些GridView时,程序会挂起并给我这个错误:OutOfMemoryExceptionoccurredinSystem.Drawing.dll我在某些部分尝试了GC.Collect()但没有成功。对于设置图像,没有代码!例如,为按钮设置图像我在visualstudio中使用了它的属性。我在可视模式下使用属性面板以这种方式设置了所有其他控件图像。这些是一些与绘图相关的设计器代码
我想使用流行的内存托管策略针对WebAPI项目运行测试。我的测试驻留在一个单独的项目中。这是我测试的开始[TestMethod]publicvoidTestMethod1(){HttpConfigurationconfig=newHttpConfiguration();config.Routes.MapHttpRoute(name:"DefaultApi",routeTemplate:"api/{controller}/{id}",defaults:new{id=RouteParameter.Optional});HttpServerserver=newHttpServer(confi
我是C#和.NET的新手,并且一直在阅读相关内容。我需要知道为什么以及什么时候需要释放资源?垃圾收集器不负责处理所有事情吗?我什么时候需要实现IDisposable,它与C++中的析构函数有何不同?此外,如果我的程序相当小,即屏幕保护程序,我是否需要关心释放资源?谢谢。 最佳答案 垃圾收集器只知道内存。这对内存力来说很好,因为只要你有足够的内存力,一点内存力就和其他任何内存力一样好。(这都是模缓存一致性等)现在将其与文件句柄进行比较。操作系统可能有足够的空间来分配更多的文件句柄-但如果您让某个特定文件的句柄处于打开状态,则其他人将无
我们有一个用.Net3.5编写的服务器组件。它在WindowsServer2008StandardEdition上作为服务运行。它工作得很好,但在一段时间(几天)后,我们注意到速度大幅下降和工作集增加。我们预计会发生某种内存泄漏,并使用WinDBG/SOS来分析进程的转储。不幸的是,GC堆没有显示任何泄漏,但我们注意到JIT代码堆已经从开始后的8MB增长到几天后的1GB以上。我们自己不使用任何动态代码生成技术。我们使用以动态代码生成而闻名的Linq2SQL,但我们不知道它是否会导致这样的问题。主要问题是是否有任何技术可以分析转储并检查WinDBG转储中显示的所有主机代码堆block来自
我有一个存在大量内存泄漏的应用程序。例如,如果打开一个View并将其关闭10次,我的内存消耗会增加,因为View没有完全清理。这些是我的内存泄漏。从测试驱动的角度来看,我想编写一个测试来证明我的泄漏,并且(在我修复泄漏之后)断言我修复了它。这样我的代码以后就不会被破坏。简而言之:有没有办法断言我的代码没有从单元测试中泄漏内存?例如我可以做这样的事情吗:objectsThatShouldNotBeThereCount=MemAssertion.GetObjects().Count;Assert.AreEqual(0,objectsThatShouldNotBeThereCount);我对