1.构造线程
构建新的线程有两种方法,一种是直接通过Thread方法构建一个线程,另一种时通过继承Thread类,重写run()方法构建。
Thread(group=None,target=None,name=None,args=(),kwargs={})
- groups :线程组,这个暂时不用管,官方文档是这样说的:“group should be None”,所以我们可以不写就行。
- target :我们要使用线程的方法
- name :线程名
- args/kwargs :传给方法的参数。要注意,如果只有一个参数,元组记得加个“,”,否则就会报错。
2.其他实例方法
- setDaemon(bool) :设置守护线程,参数默认为False,如果需要设置,则设置为True,将子线程设置成守护线程后,主线程结束,无论守护线程是否执行完毕,守护线程和主线程一起停止。看一下下面这个示例就知道了。
- 守护线程有两种设置方法,守护线程一定要在线程执行前设置,否则无效。主任务结束后,守护线程其实还没有结束,但也一起随主线程结束了。
- start() :这个不用再多介绍了,就是启动线程
- join(timeout) :这个就是为了防止主线程直接结束,先阻塞当前进程,直到调用这个方法的进程终止,或者达到设置的可选参数timeout时限。
- setName(anme)/getName(name) :设置/获取线程名字
- isAlive() :返回线程是否在运行。
- enumerate() :返回正在运行的线程名
- activeCount() : 返回正在运行的线程数
3.锁,可重入锁
具体方法如下:
acquire([timeout]): 请求获得锁定。使线程进入同步阻塞状态。
release(): 释放锁。使用前线程必须已获得锁定,否则将抛出异常。
关于线程的锁的案例,这里给出一个简单的指令锁的示例,主要看下,锁的作用。
简单的线程代码如下:
import time
import threading
def spider(a):
print("启动任务")
print(f"执行的参数为{a}")
time.sleep(5)
print(f"结束任务{a}")
print('已经结束任务')
def main():
start_time = time.time()
for i in range(1,5):
s1 = threading.Thread(target=spider, args=(i,))
s1.start()
# 等待两个子线程结束再结束主线程
s1.join()
end_time = time.time()
total_time = end_time - start_time
print(f"所有任务结束,总耗时为:{total_time}")
main()
到这里已经简单的介绍完毕。
上面内容如有侵权,请及时联系我删除。
谢谢观看!!!