当可用字节时,.Net SerialPort需要0.5秒以上的时间来读取字节

use*_*339 7 c# serial-port

我在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.
    }
}
Run Code Online (Sandbox Code Playgroud)

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

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

任何帮助非常感谢.

use*_*339 4

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

有点转移注意力,因为运行发布版本时出现通信问题的真正原因可能在其他地方。