C#中Dispose如果为空还会不会回收内存,析构函数为空呢? 5

比如这样一个类classClass1:IDisposable{publicvoidDispose(){Console.WriteLine("dis");System.GC... 比如这样一个类
class Class1 : IDisposable
{
public void Dispose()
{
Console.WriteLine("dis");
System.GC.SuppressFinalize(this);
}

~Class1()
{
Console.WriteLine("final");
}
int[] a = new int[100];
}

如果不停new可以看到内存狂涨,GC会运行、析构函数会被调用
如果用using或者手动dispose,因为有SuppressFinalize的存在就不会再调析构了,但是没看到GC调用,内存也不涨了,是C#有什么隐藏清理机制不通过函数走或者不能重载吗?
展开
 我来答
xiangjuan314
2016-05-20 · TA获得超过3.3万个赞
知道大有可为答主
回答量:2.9万
采纳率:0%
帮助的人:2906万
展开全部
关于析构函数的说明:
1。当程序的执行离开实例化自动对象所在的作用域时,自动对象就会撤销,这时析构函数隐式调用.并不是说在main函数结束时才执行。
2。析构函数本身并不释放对象占用的内存空间,它只是在系统收回对象的内存空间之前执行扫尾工作.析构函数体内并不一定要有delete语句。可以有也可以没
3。和构造函数一样,每个类都有一个析构函数,即使没有显式提供一个析构函数,编译器也会生成一个空的析构函数 .
补充说明:
离开实例化自动对象所在的作用域这句的意思就是说比如你有一个自定义类和一个自定义函数,你在这个函数里声明一个这个类的对象,这个对象就是实例化自动对象,它的作用域仅限于该函数体内,然后你在main函数里调用这个函数,调用结束后,那个类的对象就离开了它的作用域,这时,那个类的析构函数就会被编译器隐式调用。
当主函数结束,回收内存的工作就开始了,但这个工作是由编译器的内存回收机制在后台执行。如果在类的实现中,有动态分配内存和动态分配数组的语句,那么最好在析构函数里提供delete语句!
追问
问的是C# 你粘的是C++
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式