1.线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位;
2.一个进程由一个或多个线程组成,线程是一个进程中代码的不同执行路线;
3.进程之间相互独立,但同一进程下的各个线程之间共享程序的内存空间*包括代码段,数据集,堆等)及一些进程级的资源(如打开文件和信号等),某进程内的线程在其他进程不可见;
4.调度和切换:线程上下文切换比进程上下文切换要快得多
使用Threading模块创建线程
thread.start_new_thread ( function, args[, kwargs] )
- function - 线程函数。
- args - 传递给线程函数的参数,他必须是个tuple类型。
- kwargs - 可选参数。
- threading.currentThread(): 返回当前的线程变量。
- threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。
- threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。
- run(): 用以表示线程活动的方法。
- start():启动线程活动。
- join([time]): 等待至线程中止。这阻塞调用线程直至线程的join() 方法被调用中止-正常退出或者抛出未处理的异常-或者是可选的超时发生。
- isAlive(): 返回线程是否活动的。
- getName(): 返回线程名。
- setName(): 设置线程名。
使用Thread对象的Lock和Rlock可以实现简单的线程同步,这两个对象都有acquire方法和release方法,对于那些需要每次只允许一个线程操作的数据,可以将其操作放到acquire和release方法之间。锁有两种状态——锁定和未锁定。
lock和rlock都可以用来同步进程或者线程,它们之间的区别在于rlock是可重入的,也就是一个线程可以获取多次,只有在release相同次数时,rlock才会有locked状态转换为unlocked。Rlock一旦线程获得了重入锁,同一个线程再次获取它将不阻塞。
Lock在锁定时不属于特定线程,可以在一个线程中上锁,在另一个线程中解锁。而对于RLock来说,只有当前线程才能释放本线程上的锁。
import threading
import time
class myThread(threading.Thread): # 继承父类threading.Thread
def __init__(self, threadID, delay): #初始化threadID,delay
threading.Thread.__init__(self)
self.threadID = threadID
self.delay = delay
def run(self): # 把要执行的代码写到run函数里面 线程在创建后会直接运行run函数
counter = 0 #定义执行次数
while counter < 5:
time.sleep(self.delay) #延迟执行
counter += 1
print("%s: %s" % (self.threadID, time.ctime(time.time()))) #输出年月日
print("\n") #换行
class print_name(myThread): #定义输出姓名类继承父类
def __init__(self,threadID,delay):#初始化
super().__init__(threadID,delay)
def run(self):#重写run
c=0
while c<5:
time.sleep(self.delay)#延迟执行
c+=1
print("%s: %s"%(self.threadID,"张三")) #输出姓名
print("\n") #换行
# 创建新线程
thread1 = myThread(1, 2)
thread2 = print_name("姓名", 4)
# 开启线程
thread1.start()
thread2.start()