Msdn'de soldaki TreeView'de StackTrace sınıfını incelemek isterken hemen altında bulunan StopWatch sınıfı isminden dolayı baya bir gözüme battı. Neymiş diye incelerken çoğumuzun bir kodun ne kadar süre çalıştığını test etmek için DateTime.Now ile o anki zaman değerini alıp kod bitiminde Datetime.Now ile zaman değerinden bir önceki değeri çıkarma işlemini yaparız. StopWatch sınıfı ile çok daha hassas ve kesin ( Daha alt sistem API'lerini kullandığınu söyledi google ;) ) değer alabiliyormuşuz. Kullanımına dair örnek kod aşağıda.
private void button1_Click(object sender, EventArgs e) { System.Diagnostics.Stopwatch diff = new System.Diagnostics.Stopwatch(); diff.Start(); for (int i = 0; i < 2000000; i++) { int x = i >> 2 << 22 >> 222 << 2222 >> 22222 << 222222; } diff.Stop(); label1.Text = diff.Elapsed.ToString(); }
DateTime ile aynı kodu şu şekilde test ettim.
long t = DateTime.Now.Ticks;for (int i = 0; i < 2000000; i++){ int x = i >> 2 << 22 >> 222 << 2222 >> 22222 << 222222;}long t1 = DateTime.Now.Ticks;label1.Text = (t1 -t).ToString();
Remember Me