跟踪WPF中的内存泄漏

时间:2021-02-24 19:20:18

Context: We are building a framework for rapid delivery of WPF applications. This framework uses Autofac as an IoC container and also uses regions from Prism v1. We are scheduling tasks with Parallel extensions from Microsoft.

上下文:我们正在构建一个快速交付WPF应用程序的框架。该框架使用Autofac作为IoC容器,并使用Prism v1中的区域。我们正在使用Microsoft的并行扩展来安排任务。

We are facing the following problem: When we boot the application with empty views (so just a shell with regions and placeholder controls), the memory will remain stable for about 60 seconds and after that it will increase about every second with 4kb, then 4kb, after that 8kb. So every 3 seconds we have 16Kb added to our memory pressure.

我们面临以下问题:当我们使用空视图启动应用程序时(所以只有一个带有区域和占位符控件的shell),内存将保持稳定大约60秒,之后它会以4kb增加大约每秒,然后是4kb ,那之后8kb。所以每3秒钟我们就会增加16Kb的内存压力。

What have we tried to track down the leak. I started out by using dotTrace but I couldn't see any difference between 2 snapshots taken 30 minutes apart. Moved on to .NET memory profiler because it gives me more information but again we cannot see any differences between 2 snapshots. We can see that a number of objects get created but they are removed too and results in a delta of 0. So I moved on to windbg but the result is the same.

我们试图追踪什么泄漏。我开始使用dotTrace,但我看不到相隔30分钟拍摄的2张快照之间的任何差异。转移到.NET内存分析器,因为它给了我更多信息,但我们再也看不到2个快照之间的任何差异。我们可以看到创建了许多对象,但它们也被删除并导致delta为0.所以我转向windbg,但结果是一样的。

Another weird thing is that when we start sysinternals dbgvw we don't see any calls being made in our applications.

另一个奇怪的事情是,当我们启动sysinternals dbgvw时,我们看不到在我们的应用程序中进行任何调用。

Do you have any suggestions of what we might try next to find out what/who is the culprit?

你有什么建议我们可以尝试下一步找出什么/谁是罪魁祸首?

2 个解决方案

#1


If you are looking for unmanaged leaks and are using visual studio you can get surprisingly helpful information using the built in crt functions:

如果您正在寻找非托管泄漏并使用visual studio,您可以使用内置的crt函数获得令人惊讶的有用信息:

see an answer to a related question

看到相关问题的答案

#2


As it turns out it was a bug inside WPF and the workaround was to create a window handler as very first object or something. Thanks guys

事实证明这是WPF中的一个错误,解决方法是创建一个窗口处理程序作为第一个对象或东西。多谢你们

#1


If you are looking for unmanaged leaks and are using visual studio you can get surprisingly helpful information using the built in crt functions:

如果您正在寻找非托管泄漏并使用visual studio,您可以使用内置的crt函数获得令人惊讶的有用信息:

see an answer to a related question

看到相关问题的答案

#2


As it turns out it was a bug inside WPF and the workaround was to create a window handler as very first object or something. Thanks guys

事实证明这是WPF中的一个错误,解决方法是创建一个窗口处理程序作为第一个对象或东西。多谢你们