首頁  >  文章  >  後端開發  >  用C#描述資料結構1:統計程式碼執行時間物件的程式碼詳解

用C#描述資料結構1:統計程式碼執行時間物件的程式碼詳解

黄舟
黄舟原創
2017-03-08 11:47:181096瀏覽

 自訂一個統計程式碼執行時間的類別CalcTiming,考慮了:

  • 在統計執行過程中,不允許有垃圾回收。也就是在統計程式碼執行時間之前,就讓GC完成垃圾回收。

  • 確保統計的是目前行程中程式碼的執行時間。

    編寫程式碼如下:

    public class CalcTiming
    {
        TimeSpan startTime;        
        private TimeSpan endTime;
        TimeSpan duration;        
        public CalcTiming()
        {
            startTime = new TimeSpan(0);
            duration = new TimeSpan(0);
        }        public void StartTime()
        {            //强制对所有代进行垃圾回收
            GC.Collect();            //挂起线程,终结器线程清空该队列为止
            GC.WaitForPendingFinalizers();            //用户运行代码的起始时间   
            startTime = Process.GetCurrentProcess().UserProcessorTime; 

        }        //统计的代码执行完毕的时间
        public void StopTime()
        {
            endTime = Process.GetCurrentProcess().UserProcessorTime;

            duration = endTime.Subtract(startTime);           
        }        //返回统计的代码执行消耗的时间
        public TimeSpan Result()
        {            return duration;
        }

    }

  運用以上CalcTiming類,統計顯示數組的消耗時間:

    class Program
    {
        static void Main(string[] args)
        {            int[] nums = new int[100000];
            BuildArray(nums);
            CalcTiming calcTime= new CalcTiming();
            calcTime.StartTime();
            DisplayNums(nums);
            calcTime.StopTime();
            Console.WriteLine(string.Format("共用时间:{0} ms",calcTime.Result().TotalMilliseconds));
            Console.Read();
        }        static void BuildArray(int[] arr)
        {            for (int i = 0; i < 100000; i++)
                arr[i] = 1;
        }        static void DisplayNums(int[] arr)
        {            for (int i = 0; i <= arr.GetUpperBound(0); i++)
                    Console.Write(arr[i] + " ");
        }
    }

  總結,接下來用C#描述所有資料結構,統計消耗的時間時,採用CalcTiming物件。
 


#

以上是用C#描述資料結構1:統計程式碼執行時間物件的程式碼詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn