Thread.Abort并不会马上结束线程,如果后面有其它的操作可以会造成CPU跑满无法释放。
网上有写用一个循环去判断Abort状态:
while ((USBReadThread.ThreadState != System.Threading.ThreadState.Stopped) && (USBReadThread.ThreadState != System.Threading.ThreadState.Aborted))
{
Thread.Sleep(10);
}
如果想用上面的代码来实现会发现它会处于死循环的状态。
原因:“使用Thread.Sleep()方法,会使线程处于WaitSleepJoin状态,在经历Sleep()方法定义的时间段后,线程就会等待再次被操作系统调度。”
所以我收到的状态是由Background, AbortRequested 变成了Background, WaitSleepJoin, AbortRequested。
解决办法是增加:.ThreadState.HasFlag(System.Threading.ThreadState.WaitSleepJoin)来确认线程是否Aborted