DataTable与DataSet资源释放的疑问
一般情况下,要立即释放DataTable或DataSet对象所使用的资源,可以采取 obj.Dispose();obj=null; 来进行,但是,如果有以下代码应该怎么处理呢:
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
DataSet ds = new DataSet();
ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
DataTable dt2 = new DataTable();
DataSet ds = new DataSet();
ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
如果从这几行代码之后只使用ds而不再使用dt1和dt2,那么dt1和dt2是不是需要释放呢?以下代码应该是正确的:
DataTable dt1 = new DataTable();
DataTable dt2 = new DataTable();
//这里处理dt1/dt2
DataSet ds = new DataSet();
ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
dt1 = null;
dt2 = null;
//这里使用ds
ds.Dispose();
ds = null;
DataTable dt2 = new DataTable();
//这里处理dt1/dt2
DataSet ds = new DataSet();
ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
dt1 = null;
dt2 = null;
//这里使用ds
ds.Dispose();
ds = null;
问题是如果在dt1=null那两行同时使用了Dispose(),那么这里的Dispose有没有可能影响到后面对ds的使用?我觉得应该是有关系的;另一个问题是,如果没有dt1=null;dt2=null;这两行,在最后ds=null;后,两个DataTable占用的资源是否会被释放?因为这时候应该无法预知dt1和dt2是否还在使用,应该不会释放吧?
搞不清楚了,期待高手来解答,谢谢