C#如何优雅的结束一个线程Thread.Abort的坑

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

你可能感兴趣的:(C#如何优雅的结束一个线程Thread.Abort的坑)