进程和线程的区别
进程是对运行时程序的封装,是系统资源调度和分配的基本单位线程是进程的子任务,cpu调度和分配的基本单位,实现进程内并发。一个进程可以包含多个线程,线程依赖进程存在,并共享进程内存什么是线程安全
一个线程的修改被另一个线程的修改覆盖掉。
python中哪些 *** 作是线程安全的
线程同步的方式
互斥量(锁): 通过互斥机制防止多个线程同时访问公共资源。信号量(Semphare): 控制同一时刻多个线程访问同一个资源的线程数。 ps:python的threading 文档事件(信号): 通过通知的方式保持多个线程的同步。进程间的通信方式 (IPC:Inter-Process Communication 进程间传递信号或者数据)
多线程的例子
# python实现多线程import threadinglock = threading.Lock()n = [0]def foo(): with lock: # 加锁 n[0] = n[0] + 1 n[0] = n[0] + 1threads = [] # 用来储存所有线程for i in range(5000): t = threading.Thread(target=foo) # 传入foo函数 threads.append(t)for t in threads: t.start()print(n)
多进程的例子
python有GIL,可以用多进程实现cpu密集程序
multiprocessing 多进程模块multiprocessing.Process 类实现多进程一般在cpu密集的程序里面使用多进程,避免GIL的影响# 多进程import multiprocessingdef fib(n): if n<= 1: return 1 return fib(n-1) + fib(n-2)if __name__ == '__main__': jobs = [] for i in range(10,20): p = multiprocessing.Process(target=fib,args=(i,)) jobs.append(p) p.start()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
总结以上是内存溢出为你收集整理的python线程安全及多进程多线程实现方法详解全部内容,希望文章能够帮你解决python线程安全及多进程多线程实现方法详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)