关闭子窗口并结束子窗口中创建的子线程

我们在子窗口中创建一个子线程来执行耗时任务,但用户可能不想继续等待,在耗时任务结束之前就关闭了子窗口。这时会发现,虽然窗口关闭了,但是执行耗时任务的线程还在继续执行,这在大多数情况下是不合理的,而且占用系统资源,甚至会和其他进程发生冲突。下面有个方法可以在关闭子窗口时,将子线程也关闭掉。

一、添加一个窗口关闭的事件。

1.添加前台代码:

Closed="ImportWindow_Closed"

2.添加后台代码:

private void ImportWindow_Closed(object sender, EventArgs e)//该事件在窗口关闭后执行
        {
            
        }

二、在公共区域创建线程实例,以便在关闭窗口的事件中调用

Thread thread = null;
private void Import_Click(object sender, RoutedEventArgs e)
{
thread=new Thread(new ThreadStart(DoSomething));                            
                            thread.Start();
 void DoSomething()
 {

 }
}

三、在关闭窗口的事件中,执行Abort方法

private void ImportWindow_Closed(object sender, EventArgs e)//该事件在窗口关闭后执行
        {
            if (thread != null)
            { thread.Abort(); }
        }

四、如果耗时任务的线程在try块中执行,一定要添加一个catch(ThreadAbortException thAbortEx)块,因为Abort方法是通过抛出一个ThreadAbortException异常来结束进程的。全部后台代码如下

        Thread thread = null;
        private void Import_Click(object sender, RoutedEventArgs e)
        {
            try
            {
                thread = new Thread(new ThreadStart(DoSomething));
                thread.Start();
                void DoSomething()
                {

                }
            }
            catch(ThreadAbortException thAbortEx)
            {

            }
            catch (Exception ex)
            {

            }
            finally
            {

            }
        }
        private void ImportWindow_Closed(object sender, EventArgs e)//该事件在窗口关闭后执行
        {
            if (thread != null)
            { thread.Abort(); }
        }

 

在 Python ,可以使用 `threading.Event()` 来创建一个事件对象,用于控制线程的启动和停止。具体来说,可以在主窗口关闭时,设置一个事件标志,然后在线程检查这个标志,如果检测到该标志,就停止线程。 下面是一个示例代码: ```python import threading import tkinter as tk class MyThread(threading.Thread): def __init__(self, stop_event): super().__init__() self.stop_event = stop_event def run(self): while not self.stop_event.is_set(): # 线程执行的代码 pass class MyApp: def __init__(self): self.root = tk.Tk() self.stop_event = threading.Event() self.thread = MyThread(self.stop_event) self.thread.start() self.root.protocol("WM_DELETE_WINDOW", self.on_close) self.root.mainloop() def on_close(self): self.stop_event.set() # 设置事件标志,停止线程 self.thread.join() # 等待线程结束 self.root.destroy() if __name__ == '__main__': app = MyApp() ``` 在上面的代码,`MyThread` 类表示一个线程,其 `stop_event` 参数用于控制线程的启动和停止。在 `MyApp` 类,我们创建了一个 `stop_event` 对象,并将其传递给 `MyThread` 对象。然后,在主窗口关闭时,我们调用 `on_close` 方法,该方法设置事件标志,停止线程,并等待线程结束。最后,我们销毁主窗口。 请注意,上面的代码只是一个示例,具体实现方式可能因具体情况而异。例如,如果您的线程需要执行一些长时间运行的操作,您可能需要在停止线程先等待其完成。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值