优秀的编程知识分享平台

网站首页 > 技术文章 正文

C#高精度Timer和Delay以及时间测量

nanyue 2024-09-11 05:30:42 技术文章 10 ℃


在PCHMI 7.0后在工具箱里会多一个MsTimer,以及Delay和Microsecond两个类。

一、MsTimer

MsTimer和VS工具箱里的Timer用法是一样的,只是精度可以做到1毫秒,而后者的精度在15毫秒左右,而且还和系统有关系,在老版本的windows系统中只有55毫秒左右。具体用法可以参考Timer的用法。

二、Delay

Delay的延时精度会有0.5毫秒的浮动。比如延时为3毫秒那么实际延时会在2.5-3.5之间。在延时等待状态下基本不会占用CPU资源。

下面是一个测试程序:我们用一个按钮在Click事件下用一个for循环来输出每次读到的毫秒数。

PCHMI.Delay DLY = new PCHMI.Delay();

private void TEST_Click(object sender, EventArgs e)

{

string TSTR = "";

for (int I = 0; I < 50; I++)

{

TSTR += DateTime.Now.Millisecond.ToString() + "\r\n";

DLY.Sleep(1);

}

MessageBox.Show(TSTR);

}

三、Microsecond

Microsecond可以用来测量某段程序运行了多少时间,测量结果是以微秒为单位的一个浮点数。我们可以在上面代码的基础上增加两行代码来实现时间测量。

PCHMI.Delay DLY = new PCHMI.Delay();

PCHMI.Microsecond MID = new PCHMI.Microsecond();

private void TEST_Click(object sender, EventArgs e)

{

MID.Start();

string TSTR = "";

for (int I = 0; I < 50; I++)

{

TSTR += DateTime.Now.Millisecond.ToString() + "\r\n";

DLY.Sleep(1);

}

MessageBox.Show("消耗时间:"+MID.Stop().ToString()+"微秒\r\n"+TSTR);

}

注意:由于windows不是实时系统,每次测量的结果可能都会不同。

Tags:

最近发表
标签列表