当前位置:首页 > 教程 > C#/.NET获取控制台(Console)程序运行时间的方法

C#/.NET获取控制台(Console)程序运行时间的方法

在一些项目中我们总是需要去设计程序的运行时间,查看各种效率,对程序进行评估或者计算程序的执行时间长短进行计划任务。下面就介绍三种计算C#/.NET获取控制台(Console)程序运行时间的方法。
计算.NET程序运行时间

一、利用.NET自带的System.Diagnostics.StopWatch计算程序运行时间

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
static void Main(string[] args)
{
	//定义一个时间对象
	Stopwatch sw = new Stopwatch();
 
	sw.Start();//开始记录时间
	const int ExecutionCount = 1000000;
 
	for (int i = 0; i < ExecutionCount; i++)
	{
		 Console.WriteLine("知道91:"+i);
	}
	sw.Stop();//结束记录时间
	Console.WriteLine("程序的运行时间:{0} 秒",sw.Elapsed.Seconds);
	Console.WriteLine("程序的运行时间:{0} 毫秒", sw.Elapsed.Milliseconds);
}

二、根据时间函数,求十几家差

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
static void Main(string[] args)
{
	DateTime startTime = DateTime.Now;
 
	//这里执行你的逻辑程序
 
	DateTime endTime = DateTime.Now;
	System.Console.WriteLine("Total spend time:" + DateDiff(startTime, endTime));
}
/// <summary>
/// Calculate Interval Time
/// </summary>
/// <param name="startTime">Start Time</param>
/// <param name="endTime">End Time</param>
/// <returns></returns>
private static string DateDiff(DateTime startTime, DateTime endTime)
{
	string dateDiff = null;
 
	TimeSpan ts1 = new TimeSpan(startTime.Ticks);
	TimeSpan ts2 = new TimeSpan(endTime.Ticks);
	TimeSpan ts = ts1.Subtract(ts2).Duration();
	dateDiff = ts.Hours.ToString() + " hour " + ts.Minutes.ToString() + " min " + ts.Seconds.ToString() + " s ";
	return dateDiff;
}

三、利用Thread的UserProcessorTime

在.NET环境中,需要考虑程序运行所处的线程以及无用单元收集可能在任何时候发生的事实。所以在编写时间测试代码时需要考虑这些情况。在程序执行过程中无用单元收集可能会发生在任何时候。用 GC.WaitForPendingFinalizers()解决; 在.NET环境中,程序运行在被称为应用程序域的进程中Process类拥有的方法允许操作系统选取当前的进程 (程序运行其内的进程),以及选取存储线程开始执行时间的计时器。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
 class Timing
{
	TimeSpan duration;
 
	public Timing()
	{
		duration =new TimeSpan(0);
	}
 
	public void stopTime()
	{
		duration =Process.GetCurrentProcess().TotalProcessorTime;
	}
 
	public void startTime()
	{
		GC.Collect();
		GC.WaitForPendingFinalizers();
	}
 
	public TimeSpan Result()
	{
		return duration;
	}
}
 
class chapter1
{
	static void Main()
	{
		int[] nums = new int[100000];
		BuildArray(nums);
		Timing tobj = new Timing();
		tobj.startTime();
 
		DisplayNums(nums);
		tobj.stopTime();
 
		Console.WriteLine("Time: " + tobj.Result().TotalSeconds);
	}
 
	static void BuildArray(int[] arr)
	{
		for (int i = 0; i <= 99999; i++)
			arr[i] = i;
	}
 
	static void DisplayNums(int[] arr)
	{
		for (int i = 0; i <= arr.GetUpperBound(0); i++)
			Console.WriteLine(arr[i] + "");
	}
 }

上面三种方法简易不同,但是都有自己的特点,希望读者按照自己的需求去选择。

  • << 怎样打造个人成功博客教程讲解(一):...
  • 站长每天坚持写一篇文章到底有多难? >>
  • 作者:
    除非注明,本文原创:知道91,欢迎转载!转载请以链接形式注明本文地址,谢谢。
    原文链接:http://www.zhidao91.com/calculate-program-time/

    相关文章 近期热评 最新文章

    • 使用微信JDK实现微信接口签名验证
      要使用微信的接口必须在绑定的域名下测试;签名必须先向微信请求到access_token,然后用access_token再去请求jsapi_ticket,最后用jsapi_ticket和相关的参数按照ASCII码...
    • oracle数据库相关操作注意事项
      修改Oracle SGA(共享内存) 很多网站说修改Oracle的内存通过命令 如果你这么做了,那么恭喜你,你的Oracle数据库无法启动了。如果你已经这么做了,恢复Oracle启动的方...
    • oracle数据库相关操作注意事项
      修改Oracle SGA(共享内存) 很多网站说修改Oracle的内存通过命令 如果你这么做了,那么恭喜你,你的Oracle数据库无法启动了。如果你已经这么做了,恢复Oracle启动的方...
    • 使用微信JDK实现微信接口签名验证
      要使用微信的接口必须在绑定的域名下测试;签名必须先向微信请求到access_token,然后用access_token再去请求jsapi_ticket,最后用jsapi_ticket和相关的参数按照ASCII码...
    • ABP开发指南系列教程(2) – 多层架构...
      为了减少复杂性和提高代码的可重用性,采用分层架构是一种被广泛接受的技术。为了实现分层的体系结构,ABP遵循DDD(领域驱动设计)的原则,将工程分为四个层: 展现层(...
    • ABP开发指南系列教程(1) – 入...
      ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称。 ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应用程序的新起点,它旨在成为一个通用的WE...
    • Windows下 JIRA + Agile + Mysql 破解...
      本文讲述了Windows下 JIRA + Agile + Mysql 破解安装示例教程
    • c#类的构造函数继承关系示例剖析
      本文通过示例代码讲解了c#子类的构造函数与父类的关系,子类怎样集成父类的构造函数的。