一个有意思的.net应用bug

来源:互联网 发布:掘金量化 知乎 编辑:程序博客网 时间:2024/04/29 13:44

2012-12-04

有一个比较有意思的.net应用的bug。涉及到了.net的几个重要概念。

这是一个wpf的应用,使用了第三方的ribbon控件。
现象是这样的,一个window关闭之后,相同类型的window被再次打开;此时,window对应的contextual ribbon中行为只跟当前active的window的数据无关联。当前window的改变与contextual ribbon变动没有关系了。
调试后的第一发现是,哪怕所有window被关闭(对应的contextual ribbon也不见了),但contextual ribbon中的command一直被执行,而且用的数据都来自第一个window。也就是说,ribbon常驻内存,使用后就被cache了。因为ribbon 会refer到window,被关闭的同类window中的第一个,实际一直没有被GC delete,不然就报null reference异常了。
实际上也是,app会一直refer到ribbon,直到app退出,不然ribbon不会被delete。

所以,我们的目标就是ribbon应该用当前active的window。每个window被关掉后,不应该再用了。
我们发现ribbon会refer到window的地方是这样的
   Func(() =>{…},
        Presenter.CanShowInfo() // !!!here!!!
  );
这样的话,window会被直接refer到而不会被delete。我们的改法是
   Func(() =>{…},
        () => {Presenter.CanShowInfo() ;}// !!!here!!!
  );
因为lambda表达式的lazy特性,它不会refer某一个window的object,而是在用的时候才会去找,所以能找到当前active的window。

Over~


原创粉丝点击