所以,我有这个非常有用的棒程序:static void Main(string[] args){new Dictionaryint,int(10000000);while (true){System.Threading.Thread.Sleep(1000);}}这甚至不会产生编译器的任何警告,这是令人惊讶的.运行...

所以,我有这个非常有用的棒程序:
static void Main(string[] args)
{
new Dictionary<int,int>(10000000);
while (true)
{
System.Threading.Thread.Sleep(1000);
}
}
这甚至不会产生编译器的任何警告,这是令人惊讶的.
运行它会分配一块内存.如果我运行多个副本,我最终会达到一个无法启动的程度,因为我已经没有内存了.
>为什么垃圾收集器不会清理内存,而是让系统进入没有足够内存用于新进程的状态?
>哎,为什么不优化内存分配?它永远不会被任何东西引用!
那么这里发生了什么?
解决方法:
垃圾收集器是非确定性的,并且响应内存压力.如果没有什么需要内存,它可能不会收集一段时间.它不能优化掉新的,因为它改变了你的代码:构造函数可能有副作用.此外,在调试中,它甚至更有可能决定不收集.
在发布/优化版本中,我希望在有充分理由的时候收集它.还有GC.Collect,但除了极端情况或某些分析需求外,通常应该避免这种情况.
作为“为什么” – GC“代”之间的GC行为存在差异;你在“大对象堆”(LOH)上有一些大数组.这个LOH是非常昂贵的继续检查,这可以进一步解释为什么它是如此不情愿.
本文标题为:c# – 为什么这个内存没有得到清理,或者根本没有分配?


基础教程推荐
- 使用c#从分隔文本文件中插入SQL Server表中的批量数据 2023-11-24
- c#中利用Tu Share获取股票交易信息 2023-03-03
- Unity shader实现多光源漫反射以及阴影 2023-03-04
- C#中类与接口的区别讲解 2023-06-04
- C#通过GET/POST方式发送Http请求 2023-04-28
- c#读取XML多级子节点 2022-11-05
- C# Winform实现石头剪刀布游戏 2023-01-11
- C#集合查询Linq在项目中使用详解 2023-06-09
- C# – NetUseAdd来自Windows Server 2008和IIS7上的NetApi32.dll 2023-09-20
- 京东联盟C#接口测试示例分享 2022-12-02