今天写线程,再网页上找了些关闭线程的栗子,给大家整理一下~~~
多线程程序的开发中,启动了多个线程的程序在关闭的时候却出现了问题,如果程序退出的时候不关闭线程,那么线程就会一直的存在,但是大多启动的线程都是局部变量,不能一一的关闭,如果调用Thread.CurrentThread.Abort()方法关闭主线程的话,就会出现ThreadAbortException 异常,因此这样不行。
后来找到了这个办法:
所以解决办法就是在主线程初始化的时候,设置:
Thread.CurrentThread.IsBackground = true;
这样,主线程就是后台线程,在关闭主程序的时候就会关闭主线程,从而关闭所有线程。
但是这样的话,就会强制关闭所有正在执行的线程,所以在关闭的时候要对线程工作的结果保存。
C#程序的几种退出
1.Application.Exit(); //好像只在主线程可以起作用,而且当有线程,或是阻塞方法的情况下,很容易失灵
2.System.Environment.Exit(0); //无论在主线程和其它线程,只要执行了这句,都可以把程序结束干净
3.this.Close();
4.Application.ExitThread();
版本1:
在客户关闭程序时,主线程直接关闭,不考虑子线程。
问题:任务管理器中,主程序进程还在运行(在等子线程结束,而子线程做成了while(1)。)
版本2:
在主线程关闭处理时,首先关闭子线程。代码如下:
- /// <summary>
- /// 停止扫描线程
- /// </summary>
- /// <param name="Message">操作模块的提示性消息</param>
- private void StopScanThread()
- {
- Cursor.Current = Cursors.WaitCursor;
- if (this.tmCount.Enabled)
- {
- tmCount.Enabled = false;
- WaitPeriod = 0;
- }
- this.ShowStatus("正在关闭扫描端口...");
- if (monitor != null)
- {
- monitor.CloseSerialPort();
- }
- if (WorkThread[1] != null)
- {
- WorkThread[1].Abort();
- while (WorkThread[1].ThreadState != System.Threading.ThreadState.Stopped)//必须等线程完全停止了,否则会出现冲突。
- {
- Thread.Sleep(2000);
- }
- }
- this.ShowStatus("数据采集已停止...");
- Cursor.Current = Cursors.Arrow;
- }
/// <summary>
/// 停止扫描线程
/// </summary>
/// <param name="Message">操作模块的提示性消息</param>
private void StopScanThread()
{
Cursor.Current = Cursors.WaitCursor;
if (this.tmCount.Enabled)
{
tmCount.Enabled = false;
WaitPeriod = 0;
}
this.ShowStatus("正在关闭扫描端口...");
if (monitor != null)
{
monitor.CloseSerialPort();
}
if (WorkThread[1] != null)
{
WorkThread[1].Abort();
while (WorkThread[1].ThreadState != System.Threading.ThreadState.Stopped)//必须等线程完全停止了,否则会出现冲突。
{
Thread.Sleep(2000);
}
}
this.ShowStatus("数据采集已停止...");
Cursor.Current = Cursors.Arrow;
}
问题:主程序关不掉,类似于死机状。
版本3:改进一下,在程序启动时强制停止同名进程。在Program.cs的main方法中实现,代码如下:
- #region 杀死由于上次关闭软件而未停掉的进程(多线程的副作用)
- Process[] processes = System.Diagnostics.Process.GetProcesses(); //获得所有进程
- foreach (Process p in processes)
- {
- if (p.ProcessName == "WaterMonitorIS_Weiding" && p.StartTime < DateTime.Now.AddMinutes(-2))
- {
- p.Kill();
- }
- }
- #endregion
#region 杀死由于上次关闭软件而未停掉的进程(多线程的副作用)
Process[] processes = System.Diagnostics.Process.GetProcesses(); //获得所有进程
foreach (Process p in processes)
{
if (p.ProcessName == "WaterMonitorIS_Weiding" && p.StartTime < DateTime.Now.AddMinutes(-2))
{
p.Kill();
}
}
#endregion
版本4:(终结版本)
C#多线程编程时,Thread对象有个IsBackground属性,设置为true即可,在主线程关闭时,子线程随之关闭,速度很快。
- workThread.IsBackground = true;
转自 :http://blog.sina.com.cn/s/blog_66dc2c130100k534.html
http://blog.csdn.net/effectiveagui/article/details/7841792