我一直在尝试追踪我认为与线程相关的错误,但我认为我使用OpenNETCF的秒表的方式存在问题。我在我的应用程序中使用OpenNETCF.IoC,但为了简单起见,我将以下代码直接移到了视图中:
public partial class WorkoutView : SmartPart
{
...
private Stopwatch stopwatch;
public WorkoutView()
{ ...
stopwatch = new Stopwatch();
stopwatch.Reset();
stopwatch.Start();
WorkoutDisplayTimer = new Timer();
WorkoutDisplayTimer.Interval = 500;
WorkoutDisplayTimer.Tick += new EventHandler(WorkoutDisplayTimer_Tick);
WorkoutDisplayTimer.Enabled = true;
}
void WorkoutDisplayTimer_Tick(object sender, EventArgs e)
{ ...
stopwatch.Stop();
lbl.Text = stopwatch.ElapsedTicks.ToString() + "NOT WORKING: " + stopwatch.Elapsed.ToString();
stopwatch.Start();
}
...
}
长话短说,在调试器中查看秒表,唯一得到更新的值是ElapsedTicks,mElapsed,mStartPerfCount。其他一切都是零。这是预期的行为吗?我是否需要调用另一种方法让秒表计算Elapsed结构? (注意:秒表.ElapsedMilliseconds也为零)
答案 0 :(得分:2)
是的,它似乎是一个错误,特别是在Stopwatch.cs第136行。
目前的内容如下:
smFreqInTicks = (MILLIS_IN_TICKS * 1000) / freq;
应该是:
smFreqInTicks = (MILLIS_IN_TICKS * 1000d) / freq;
现在smFreqInTicks最终总是为零,这会杀死你正在看的值。
答案 1 :(得分:1)
为什么不在Compact Framework中使用该版本?从版本3.5开始,它位于there ......