我在串口上快速接收数据,而在其他线程中我正在处理串口上收到的数据包。因此,对于线程安全的读写操作,我使用concurrentqueue。以下是我在串行端口上接收数据的代码,我将其存储在concurrentqueue中。
System.Collections.Concurrent.ConcurrentQueue<byte> receivedData = new System.Collections.Concurrent.ConcurrentQueue<byte>();
private void receiveData(object sender, SerialDataReceivedEventArgs e)
{
while (connectComPort.BytesToRead > 0)
{
receivedData.Enqueue((byte)connectComPort.ReadByte());
}
}
以下是在后台线程中运行的concurrentqueue中处理数据的代码。
private void processBuffer()
{
while (1 == 1)
{
try
{
List<byte> storeData = new List<byte>();
if (startProcessState == 0)
{
storeData.Clear();
break;
}
if (receivedData.Count() > 7)
{
byte first = 0x00;
receivedData.TryPeek(out first);
if (startProcessState == 0)
{
storeData.Clear();
break;
}
if (first == 0x55)
{
first = 0x00;
receivedData.TryDequeue(out first);
storeData.Add(first);
receivedData.TryPeek(out first);
if (first == 0xAA)
{
receivedData.TryDequeue(out first);
storeData.Add(first);
if (receivedData.TryDequeue(out first))
{
storeData.Add(first);
receivedData.TryDequeue(out first);
storeData.Add(first);
receivedData.TryPeek(out first);
int sizeBytes = (int)first;
int numbTimesLoop = sizeBytes - 4;
for (int i = 0; i < numbTimesLoop; i++)
{
receivedData.TryDequeue(out first);
storeData.Add(first);
}
//File.AppendAllText("hello5.txt", BitConverter.ToString(storeData.ToArray()) + Environment.NewLine);
modifiedProcess(storeData); //-- Line 1
}
}
else
{
receivedData.TryDequeue(out first);
}
}
else
{
receivedData.TryDequeue(out first);
}
}
else
{
Thread.Sleep(30);
}
}
catch (Exception ex)
{
Log.Error("huge bug : " + ex.ToString());
}
}
问题是在调用第1行功能之前发生了数据损坏。一些字节转换为0x00(我已在发送方端检查,因此正在串口的另一端发送正确的数据。)。在第1行之前,如果我将数据写入文件,那么我不会在写入文件的数据包中看到此错误。这个错误的可能原因是什么?我假设concurrentqueue不是完全线程安全的。
答案 0 :(得分:7)
您应该使用TryPeek
和TryDequeue
返回的返回值。如果这些返回false
(例如,因为队列中没有任何内容),您最终会得到0x00
。