gpt4 book ai didi

c# - WeakReferences 在嵌入式操作系统中没有被释放

转载 作者:可可西里 更新时间:2023-11-01 08:46:52 27 4
gpt4 key购买 nike

我在这里有一个奇怪的行为:我在运行在 DLOG 终端(Windows Embedded Standard SP1)上运行的 WPF 应用程序的生产中出现大量内存泄漏,如果我在普通桌面(Win7 教授)上本地运行它,它表现得非常好

在多次尝试发现任何问题均未成功后,我将其中一个直接放在我的显示器旁边,安装了 ANTs MemoryProfiler,并在终端和我的开发 PC 上模拟用户操作进行了一个小时的测试运行。

结果是,由于一些奇怪的原因,嵌入式系统堆积了大量的 WeakReference 和 EffectiveValueEntry[] 对象。

下面是一些图片:

开发(PC): enter image description here

enter image description here

终端: enter image description here

看看类(class)列表... enter image description here

有没有人以前见过这样的事情,是否有已知的解决方案?我在哪里可以获得帮助?

(请注意安装了为 .net4 准备的图像的终端)

PPS:对于关系密切的选民:我认为问题很明确:我该如何解决这个问题。你可能会争论这是一个 IT/OS 问题还是一个编程问题,但我认为如果我在 Server Fault 中发布它,它会立即关闭主题......

更新:我能够找到问题的很大一部分——但感觉有点像 C++:我将类似 ViewModel 的 Items 类用于提供(除其他外)ICommand(RelayCommand 模式)的 WPF 列表。在 View 的 ViewModel-Property 的 getter 中即时创建的项目,似乎应用程序/GC 从未释放那些未使用的命令 - 或者对其 CanExecuteChanged 的​​订阅 - 内存分析器将这些显示为“由弱引用”。我更改了我的代码以重用那些项目 View 模型,并将 Dispose/set 中的每个使用过的属性都设置为空,并将其用作清理 - 正如我所说:在那些旧的 C++ 时代感觉就像“删除”。最重要的是,我每 30 分钟使用一次强制 GC.Collect(是的,我知道 - 你永远不应该 - 但到目前为止我没有其他解决方案)。使用此设置,应用程序可以运行 6 个多小时,到目前为止没有问题,但感觉不对。

我不明白为什么那些 WeakReferences 没有声明,因为它们在我的台式机上......

对此有什么想法吗?请!

更新:我仍然无法确定这个问题,但我看到了一个奇怪的行为:如果我使用 PC-Anywhere 观察我的软件在其中一个终端上的运行,问题就会消失!即使在运行 8 小时后。软件直接运行 - 它甚至会释放内存(我在主屏幕上放了一个小内存计数器 - 假设我连接到终端并看到内存不足 - 等待几分钟后内存被回收)

所以我认为 Devin(下面的一个答案)在正确的方向上处于领先地位 - 远程控制软件中的某些东西可以解锁终结器线程或任何阻止 GC 的东西 - 无论是模拟键盘/鼠标还是其他任何东西。

对此有什么想法吗?

最佳答案

我们在平板电脑上运行我的应用程序时遇到了(有点)类似的问题。在台式机上运行时会回收内存,但在平板电脑或其他使用 PC 输入面板的设备上运行时则不会。问题是终结队列卡住了。 COM 对象终结器正在等待在没有消息循环的主线程上运行某些东西。

解决方案是找到足够的时间来调用 Application.DoEvents()。我们有一个会间歇性调用的方法,我们每调用 10 次就会调用它。我不知道这是否与您遇到的问题相同,但也许它可以阐明一些问题。

编辑:我确实需要说清楚,一般来说,调用 DoEvents() 是个坏主意。它在这种情况下有效,因为该线程上没有任何 UI 或这些事件可能干扰的任何其他事件。

关于c# - WeakReferences 在嵌入式操作系统中没有被释放,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10173185/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com