set xxx=nothing就是把对象占用的空间释放掉。 其他的局部变量都在栈内存,用完会自动释放的
创新互联自2013年起,先为太谷等服务建站,太谷等地企业,进行企业商务咨询服务。为太谷企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
'使用完毕保存修改
AppXls.ActiveWorkbook.Close(SaveChanges:=True)
'必须退出Excel对象
AppXls.Quit()
.NET目前的垃圾回收机制不能实现把对象真正的立即释放掉,GC会对垃圾进行管理,如果垃圾没有引用计数了,就会被回收。
编码的时候能用托管类尽量用托管类去实现你的功能,
对于实现了IDisposable接口的类,用完了记得调用close或者Dispose又或者相应的方法去释放资源,最好吧使用using语句块;
对于Com对象,用完了先关闭,然后调用Runtime.InteropServices.Marshal.FinalReleaseComObject()方法把Com对象的引用计数设置为0。当 COM 对象的引用计数变为 0 时,通常会释放 COM 对象,不过这取决于 COM
对象的实现,而不是运行时可以控制的。最后调用ComObj = Nothing以释放ComObj持有的引用。不过要注意,只有当ComObj的生存期相对于垃圾回收器用于检测孤立对象的时间来说很长时,你才应该将变量设置为 Nothing。
有部分来自MSDN
对象释放后还怎么打开啊,要不就不释放,先隐藏起来,要不就新建一个