Kod yazarken .Net en önemli güzelliklerinden biride Çöp toplayıcılarının(garbage Collection) olması yani .net işi biten nesneyi sizin dispose edip öldürmenize bakmadan doğrudan öldürerek müthiş bir performans kazandıra biliyor fakat veritabanı nesneleri oluşturulduktan sonra bağlantı hala devam ettiği için (connection Open durumu) bağlantı bir try-catch-finally blogları içinde dispose edilmesi unutulduğundan genelde bellek canlı bir şekilde kalır ve programımızın içine etmeye başlar
try-catch-finally bloğunu kullanmakta son derece sinir bozucu olup bir sürü offflayarak kod yazmanıza neden olur .Örneğin
SqlConnection cn = null;
SqlCommand cm = null;
try
{
cn = new SqlConnection(connectionString);
cm = new SqlCommand(commandString, cn);
cn.Open();
cm.ExecuteNonQuery();
}
finally
{
if (null != cm)
cm.Dispose();
if (null != cn)
cn.Dispose();
}
Aynı kodu using kullaarak pek âla yapabilirdik.
using (SqlConnection cn = new SqlConnection(connectionString))
{
using (SqlCommand cm = new SqlCommand(commandString, cn))
{
cn.Open();
cm.ExecuteNonQuery();
}
}
Böylece Using kodu bizim otomatik olarak nesnelerimizin yok edilmesini sağlayarak Garbage Collectionı tetikleyebiliyor.
Hiç yorum yok:
Yorum Gönder