mono的gc问题

mono的gc一直 使用 conservative gc..可见其文档的描述。是一种较为落后的实现,没有分代。在最近的2.8版本中多了

一种sgen的新gc..据称性能不错..原来的gc一直有precise stack scanning的问题。在一些stack上分配的对象存在无法收集的可能性。

 

前天看到一文:

http://flyingfrogblog.blogspot.com/2010/07/mono-24-still-leaking-like-sieve.html

 

需要凸墙...

 

作者用了一个简单的代码来证实这种memory leak的存在。我用c#改写了,代码如下:

 

public class MainS
    {
        public static void Main(string[] args)
        {
            for(var i = 0; i!=30; ++i)
            {
                var t = new Dictionary<int,int>();               
                for(var j = 0; j!=10000000; ++j)
                {
                   
                    t[j] = j;
                }
                Console.WriteLine(string.Format("{0},{1}",t.Count,i));
                //GC.Collect();
            }
            Console.WriteLine("haha");
        }
    }

 

此段代码在 mono 默认的gc上无法执行,会报outofmemory的错误..在新的sgen gc上勉强可以运行一阵子,但是最终会报sgen内部的一些错误。如果想要正确运行。那么可以把注释的部分打开 。。或者加入t.Clear()。这样在sgen gc下可以正常运行。在原有的gc依然不行。。

 

此段代码在注释掉gc.collect下在ms .net 3.5, .net 4.0均可以正常运行。现在看来mono的gc虽然有进步但是还不尽人意。。

 

出于好奇,我在python也实现了同样的代码,也没有任何问题。

 

据roadmap称,mono 2.10在gc方面将会有比较大的改进,希望如此。

 

测试环境: ubuntu10.04 32 bit, mono 2.8.2

                    windows 7 64 bit, .net 4.0, .net 3.5

 

有趣的是,如果把i 和 j的值 互换并不会出现问题。。看起来似乎mono的gc对 stack的大量对象存在回收的问题...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值