一:进程
- 进程概念
- 进程就是一个程序运行在一个数据集上的一次动态执行过程
- 进程一般由程序,数据集,进程控制块组成
- 进程控制块: 进程控制块用来记录进程的外部特征,描述进程的执行变化过程,系统可以利用它来控制和管理进程,它是系统感知进程存在的唯一标志(通俗讲就是记录进程状态信息)
二:线程
- 线程概念
一:线程的创建与调用(threading中Thread类)
- 创建一个主线程的子线程对象
- t1=threading.Thread(target=read)
- target:指向函数,arg:传递函数参数
- 启用一个子线程
- t1.start()
- 实际start()只是让线程处于就绪态,开始一个线程时run()方法实现的


1 import threading 2 import time 3 def read(): 4 print("I am reading at %s"%time.ctime()) 5 time.sleep(3) 6 print("i am finish reading at %s"%time.ctime()) 7 def music(): 8 print("i am listening music at %s"%time.ctime()) 9 time.sleep(3) 10 print("i am finish listening music at %s"%time.ctime()) 11 if __name__=="__main__": 12 t1=threading.Thread(target=read)#创建这个程序的主线程的子线程对象 13 #target:指向调用的函数,arg用于传递函数中的参数 14 t1.start()#启用某个线程 15 t2=threading.Thread(target=music) 16 t2.start()
1.首先t1,t2与主线程开启,直接输出 I am reading at Thu Jan 31 12:20:38 2019 I am listening music at Thu Jan 31 12:20:38 2019 Main threading ending at Thu Jan 31 12:20:38 2019... 2.俩个进程等待三秒钟 3.最后输出 I am finish listening music at Thu Jan 31 12:20:41 2019 I am finish reading at Thu Jan 31 12:20:41 2019
二:join的用法理解


1 import threading 2 import time 3 def read(): 4 print("I am reading at %s"%time.ctime(),end=" ") 5 time.sleep(3) 6 print("I am finish reading at %s"%time.ctime(),end=" ") 7 def music(): 8 print("I am listening music at %s"%time.ctime()) 9 time.sleep(5) 10 print("I am finish listening music at %s"%time.ctime(),end=" ") 11 if __name__=="__main__": 12 t1=threading.Thread(target=read)#创建这个程序的主线程的子线程对象 13 #target:指向调用的函数,arg用于传递函数中的参数 14 t2=threading.Thread(target=music) 15 t1.start() # 启用某个线程 16 t2.start() 17 #t1.join() 18 t2.join() 19 print(r"main threading ending at %s..."%time.ctime())
- 没有join时,主线程开子线程一起执行
- 注释掉t2.join()
-
-
-
1.执行t1,t2子线程 I am reading at Thu Jan 31 13:09:39 2019 I am listening music at Thu Jan 31 13:09:39 2019 2.进入等待3秒钟 3.执行t1子线程和主线程 I am finish reading at Thu Jan 31 13:09:42 2019
main threading ending at Thu Jan 31 13:09:44 2019... 4.进入等待俩秒钟 5。执行t2 I am finish listening music at Thu Jan 31 13:09:44 2019
-
-
- 注释掉t1.join
-
-
1.执行t1,t2子线程 I am reading at Thu Jan 31 13:20:50 2019 I am listening music at Thu Jan 31 13:20:50 2019 2.进入等待5秒钟,单线程1只需等待三秒钟,所以在三秒钟时会继续执行ti线程 I am finish reading at Thu Jan 31 13:20:53 2019 3.在三秒钟后在过俩秒钟执行t2和主线程 I am finish listening music at Thu Jan 31 13:23:28 2019 main threading ending at Thu Jan 31 13:23:28 2019...
-
-
- 都不注释
-
-
1.执行t1,t2子线程 I am reading at Thu Jan 31 13:26:55 2019 I am listening music at Thu Jan 31 13:26:55 2019 2,进入等待5秒,在第三秒执行t1 I am finish reading at Thu Jan 31 13:26:58 2019 3.再过俩秒执行t2和主线程 I am finish listening music at Thu Jan 31 13:27:00 2019 main threading ending at Thu Jan 31 13:27:00 2019...
-
-
三:总结
在没有join时,主线程会与子线程同时执行,但当子线程有了设置了join时,主线程会等待带有join的子线程执行完毕再结束,如果一个进程的join设置再另一个线程开始之前,后者会在前者执行完毕再执行,如果是x.start+x.join+x1.start+x1.join。。。这种格式就成了穿行
- 守护线程的概念
-
只要主线程完成了,不管守护子线程是否完成,都要和主线程一起退出,整个Python会在所有的非守护线程结束后才会结束,即进程中没有非守护线程存在的时候才结束
-
- setDaemon方法实例理解

1 import threading 2 import time 3 def read(): 4 print("I am reading at %s"%time.ctime(),end=" ") 5 time.sleep(3) 6 print("I am finish reading at %s"%time.ctime(),end=" ") 7 def music(): 8 print("I am listening music at %s"%time.ctime()) 9 time.sleep(5) 10 print("I am finish listening music at %s"%time.ctime(),end=" ") 11 if __name__=="__main__": 12 t1=threading.Thread(target=read) 13 t2=threading.Thread(target=music) 14 t1.setDaemon(True) 15 t1.start() 16 t2.start() 17 print(r"main threading ending at %s..."%time.ctime())
一.设置t1为守护线程是看不到效果的,因为,主进程在所有非守护线程结束了才会结束 二:设置t2为守护线程 1.首先执行t1,t2和主线程 执行结果: I am reading at Fri Feb 1 20:28:58 2019 I am listening music at Fri Feb 1 20:28:58 2019 main threading ending at Fri Feb 1 20:28:58 2019... 2.由于主线程会在所有非守护线程结束后才结束,所以非守护线程t1在3秒后结束,从而主线程结束,t2被迫 结束 执行结果: I am finish reading at Fri Feb 1 20:29:01 2019 Process finished with exit code 0
# run(): 线程被cpu调度后自动执行线程对象的run方法 # start():启动线程活动。 # isAlive(): 返回线程是否活动的。 # getName(): 返回线程名。 # setName(): 设置线程名。 threading模块提供的一些方法: # threading.currentThread(): 返回当前的线程变量。
#<_MainThread(MainThread, started 14428)>#输出的主线程名字MainThread # threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
#[<_MainThread(MainThread, started 13548)>, <Thread(Thread-1, started 10348)>, <Thread(Thread-2, started 18144)>]
#从这里可以发现主线程实在所有线程结束后才结束
# threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。
最后补充一下线程的类调用方法 https://www.cnblogs.com/yuanchenqi/articles/6248025.html