使用 C# 测量程序运行消耗的的时间

对于大多数任务,您可以使用Stopwatch或DateTime类来测量经过的时间。

要使用Stopwatch类,请创建一个Stopwatch对象。使用其Start和Stop方法启动和停止它。如果在停止对象后使用Start,时间将从停止的地方开始。这使得该类在您想要添加多个间隔时特别有用。使用Reset方法将时间重置为 0。使用StartNew方法创建一个新的Stopwatch并单步启动它。使用Stopwatch类的Elapsed属性获取表示已用时间的 TimeSpan对象。

要使用DateTime类,请使用静态Now属性来获取执行某些代码之前和之后的当前时间。将结果保存在DateTime变量中。然后减去它们以获得表示已用时间的 TimeSpan 。

当程序启动时,它使用以下代码准备运行并显示有关Stopwatch类的信息。

cs 复制代码
private DateTime StartTime, StopTime;
Stopwatch StopWatch;
Stopwatch TotalWatch = new Stopwatch();

private void Form1_Load(object sender, EventArgs e)
{
    txtFrequency.Text = Stopwatch.Frequency.ToString();
    txtNsPerTick.Text = (1000000000 / Stopwatch.Frequency).ToString();
    txtIsHighRes.Text = Stopwatch.IsHighResolution.ToString();
}

代码首先声明了两个DateTime和两个Stopwatch。窗体的Load事件处理程序显示Stopwatch类的频率(每秒滴答数)值和每滴答的纳秒数。它还指示该类是否使用高精度计时。在较旧的计算机上, 最后一项可能返回false 。

当您单击"开始"按钮时,将执行以下代码。

cs 复制代码
private void btnStart_Click(object sender, EventArgs e)
{
    btnStart.Enabled = false;
    btnStop.Enabled = true;
    txtElapsed1.Clear();
    txtElapsed2.Clear();
    txtElapsed3.Clear();

    StartTime = DateTime.Now;
    StopWatch = Stopwatch.StartNew();
    TotalWatch.Start();
}

此代码禁用"开始"按钮并启用"停止"按钮。然后清除结果文本框。

接下来,代码将StartTime设置为当前时间。然后创建并启动一个新的Stopwatch,并将其保存在变量StopWatch中。最后,它重新启动TotalWatch Stopwatch对象。

单击"停止"按钮时,将执行以下代码。

cs 复制代码
private void btnStop_Click(object sender, EventArgs e)
{
    StopTime = DateTime.Now;
    StopWatch.Stop();
    TotalWatch.Stop();

    TimeSpan elapsed = StopTime.Subtract(StartTime);
    txtElapsed1.Text = elapsed.TotalSeconds.ToString("0.000000");

    txtElapsed2.Text = StopWatch.Elapsed.TotalSeconds.ToString("0.000000");

    txtElapsed3.Text = TotalWatch.Elapsed.TotalSeconds.ToString("0.000000");

    btnStart.Enabled = true;
    btnStop.Enabled = false;
}

此代码单击"停止"按钮,程序将DateTime.Now记录在变量StopTime中,并停止两个Stopwatch。然后它显示这三种方法记录的经过时间。

如果您运行该程序几次,您将看到DateTime和Stopwatch类产生非常接近相同的结果。

相关推荐
林开落L18 分钟前
库制作与原理(下)
linux·开发语言·centos·库制作与原理
fengfuyao9851 小时前
基于MATLAB的GUI实现人脸检测、眼睛检测以及LBP直方图显示
开发语言·计算机视觉·matlab
★YUI★1 小时前
学习游戏制作记录(玩家掉落系统,删除物品功能和独特物品)8.17
java·学习·游戏·unity·c#
CHANG_THE_WORLD1 小时前
# C++ 中的 `string_view` 和 `span`:现代安全视图指南
开发语言·c++
Franklin1 小时前
Python界面设计【QT-creator基础编程 - 01】如何让不同分辨率图像自动匹配graphicsView的窗口大小
开发语言·python·qt
谷宇.2 小时前
【Unity3D实例-功能-拔枪】角色拔枪(二)分割上身和下身
游戏·unity·c#·游戏程序·unity3d·游戏开发·游戏编程
郝学胜-神的一滴2 小时前
深入理解QFlags:Qt中的位标志管理工具
开发语言·c++·qt·程序人生
LZQqqqqo2 小时前
C# 中 ArrayList动态数组、List<T>列表与 Dictionary<T Key, T Value>字典的深度对比
windows·c#·list
柯南二号2 小时前
【Java后端】MyBatis-Plus 原理解析
java·开发语言·mybatis
我是哈哈hh3 小时前
【Node.js】ECMAScript标准 以及 npm安装
开发语言·前端·javascript·node.js