OpenNETCF.Stopwatch - >只有嘀嗒声变化,而不是经过

时间:2010-03-31 14:09:59

标签: c# windows-mobile compact-framework opennetcf opennetcf.ioc

我一直在尝试追踪我认为与线程相关的错误,但我认为我使用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也为零)

2 个答案:

答案 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 ......