C#高精度Timer和Delay以及时间测量
在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不是实时系统,每次测量的结果可能都会不同。