相关文章推荐
强悍的大蒜  ·  浅谈电子数据质量问题及解决方法_审计署网站·  1 年前    · 
卖萌的滑板  ·  java - Instant 和 ...·  1 年前    · 
另类的饭盒  ·  在 importlib.reload() ...·  1 年前    · 
才高八斗的双杠  ·  这样教都不会?还得我亲自出马!-我亲自出马·  2 年前    · 
Code  ›  python中threading开启关闭线程操作开发者社区
python python函数 线程 python继承
https://cloud.tencent.com/developer/article/1738423
个性的小蝌蚪
1 年前
作者头像
砸漏
0 篇文章

python中threading开启关闭线程操作

前往专栏
腾讯云
备案 控制台
开发者社区
学习
实践
活动
专区
工具
TVP
文章/答案/技术大牛
写文章
社区首页 > 专栏 > 恩蓝脚本 > 正文

python中threading开启关闭线程操作

发布 于 2020-11-02 16:23:45
6.1K 0
举报

在python中启动和关闭线程:

首先导入threading

import threading

然后定义一个方法

def serial_read():

然后定义线程,target指向要执行的方法

myThread = threading.Thread(target=serial_read)

启动它

myThread.start()

二、停止线程

不多说了直接上代码

import inspect
import ctypes
def _async_raise(tid, exctype):
  """raises the exception, performs cleanup if needed"""
  tid = ctypes.c_long(tid)
  if not inspect.isclass(exctype):
    exctype = type(exctype)
  res = ctypes.pythonapi.PyThreadState_SetAsyncExc(tid, ctypes.py_object(exctype))
  if res == 0:
    raise ValueError("invalid thread id")
  elif res != 1:
    # """if it returns a number greater than one, you're in trouble,
    # and you should call it again with exc=NULL to revert the effect"""
    ctypes.pythonapi.PyThreadState_SetAsyncExc(tid, None)
    raise SystemError("PyThreadState_SetAsyncExc failed")
def stop_thread(thread):
  _async_raise(thread.ident, SystemExit)

停止线程

stop_thread(myThread)

补充知识:python threading实现Thread的修改值,开始,运行,停止,并获得内部值

下面的半模版代码在 win7+python3.63 运行通过并且实测可行,为了广大想要实现python的多线程停止的同学

import threading
import time
class MyThread(threading.Thread):
  def __init__(self):
    threading.Thread.__init__(self)
    self.Flag=True        #停止标志位
    self.Parm=0         #用来被外部访问的
    #自行添加参数
  def run(self):
    while(True):
      if(not self.Flag):
        break
      else:
        time.sleep(2)
  def setFlag(self,parm):     #外部停止线程的操作函数
    self.Flag=parm #boolean
  def setParm(self,parm):     #外部修改内部信息函数
    self.Parm=parm
  def getParm(self):       #外部获得内部信息函数
    return self.Parm
if __name__=="__main__":
  testThread=MyThread()
  testThread.setDaemon(True)     #设为保护线程,主进程结束会关闭线程
  testThread.getParm()      #获得线程内部值
  testThread.setParm(1)      #修改线程内部值
  testThread.start()       #开始线程
  print(testThread.getParm())    #输出内部信息
  time.sleep(2)          #主进程休眠 2 秒
  testThread.setFlag(False)      #修改线程运行状态
  time.sleep(2)          #2019.04.25 修改
  print(testThread.is_alive())  #查看线程运行状态

于2018-08-24修正一次,修正为在继承thread.Thread时,没有对父类初始化

旧:

def __init__(self):
    self.Flag=True        #停止标志位
    self.Parm=0         #用来被外部访问的
 
推荐文章
强悍的大蒜  ·  浅谈电子数据质量问题及解决方法_审计署网站
1 年前
卖萌的滑板  ·  java - Instant 和 LocalDateTime 有什么区别? - SegmentFault 思否
1 年前
另类的饭盒  ·  在 importlib.reload() 之后,Python 模块没有重新加载。
1 年前
才高八斗的双杠  ·  这样教都不会?还得我亲自出马!-我亲自出马
2 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号