我在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属性设置为更小的值以防止它无限期地坐在那里,但是这个属性似乎被忽略了.
任何帮助非常感谢.
事实证明,连接到调试器的运行导致了问题。在调试器外部运行时,记录的读取一个字节的最长时间约为 20 毫秒,而在调试器内运行时则长达 700 毫秒(无断点、条件或以其他方式启用)。
有点转移注意力,因为运行发布版本时出现通信问题的真正原因可能在其他地方。
| 归档时间: |
|
| 查看次数: |
563 次 |
| 最近记录: |