7

我在 C# 中使用 .Net SerialPort 类从端口读取字节。收到 DataReceived 事件后,我检查串行端口以查看是否可以读取字节。但是,即使字节可用,端口也可能需要半秒多的时间来读取单个字节。代码大致如下:

...
while(Port.BytesToRead > 0) 
{
    StopWatch.Restart();
    Int32 BytesRead = Port.Read(Read, 0, 1);
    StopWatch.Stop();
    if (StopWatch.ElapsedMilliseconds > 100)
    {
    // Record the time. The stopwatch code
    // was only added after performance issues were observed.
    }
}

请注意,我测量的时间不是读取所有字节的时间,而是读取单个字节的时间。我经常会收到一个 DataReceived 事件,并且必须等待 0.5 秒才能读取第一个字节。

我实际上已经尝试将 Port 的 ReadTimeout 属性设置为更小的值,以防止它无限期地坐在那里,但这个属性似乎被忽略了。

非常感谢任何帮助。

4

1 回答 1

4

事实证明,连接到调试器的运行导致了问题。在调试器外部运行时,记录读取字节的最长时间约为 20 毫秒,而在调试器内部运行时最长为 700 毫秒(无断点、条件或以其他方式启用)。

有点红鲱鱼,因为运行发布版本时通信问题的真正原因可能在其他地方。

于 2012-10-23T14:09:57.687 回答