博客
关于我
python调试解决tkinter退出窗口后主线程不结束的问题
阅读量:267 次
发布时间:2019-03-01

本文共 1318 字,大约阅读时间需要 4 分钟。

tkinter关闭窗口后程序并未退出:检查这时共有7个线程。

threading.active_count()7threading.current_thread()<_MainThread(MainThread, started 140695305631552)>threading.enumerate()[<_MainThread(MainThr...05631552)>, 
,
, <_TimeoutThread(Thre...58498816)>,
,
,
]special variables:function variables:0: <_MainThread(MainThread, started 140695305631552)>1:
2:
3: <_TimeoutThread(Thread-4, started daemon 140695258498816)>4:
5:
6:
special variables:function variables:additional_info: <_pydevd_bundle.pydevd_cython.PyDBAdditionalThreadInfo object at 0x7ff590656580>daemon: Falseident: 140692661450496name: 'Thread-7'native_id: 6254stop_reason: 105_args: ()_bootstrap:
>_bootstrap_inner:
>_daemonic: False_delete:
>_ident: 140692661450496_initialized: True_invoke_excepthook:
.invoke_excepthook at 0x7ff590404a60>_is_stopped: False_kwargs: { }_name: 'Thread-7'_native_id: 6254_reset_internal_locks:
>_set_ident:
>_set_native_id:
>_set_tstate_lock:
>_started:
_stderr: <_io.TextIOWrapper name='
' mode='w' encoding='utf-8'>_stop:
>_target:
>_tstate_lock:
_wait_for_tstate_lock:
>len(): 7

在tkinter退出窗口后,走完最后一条程序代码,发现终端并没有退出,仍在运行,这时在vs code的调试模式下点暂停,

在这里插入图片描述
发现他在调用这个函数!我回头去看,发现这个函数有while True,我单独给他设置了一个线程,这显然会导致他无限运行下去。
改完后正常了。
启示:tkinter没有问题,找自己代码的原因。每次运行风扇都嗡嗡叫,早应该意识到这点。

转载地址:http://uoja.baihongyu.com/

你可能感兴趣的文章
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat怎样同步两个数据库中的表
查看>>
Navicat怎样筛选数据
查看>>
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>