并发编程
并发编程是网络编程中必须考虑的问题,实现并发的方式有多种:多进程,多线程,IO多路复用. python中调用的是操作系统的线程和进程. 进程: 进程表示资源分配的基本单位,是调度运行的基本单位.例如,用户运行一个程序时,系统就创建一个进程,为它分配资源,然后放入进程就绪队列.进程调度程序选中它,为它分配CPU,进程就开始运行.进程是系统中的并发执行单位.进程之间有数据隔离,进程是为了提供线程工作的环境. 线程: 线程是进程中执行运算的最小单位,也是执行CPU调度的基本单位.线程属于进程,线程运行在进程空间内,同一进程产生的线程共享同一内存空间,当进程退出的时候,该进程产生的所有线程都会被强制退出并清除.线程可与属于同一进程的其他线程共享进程拥有的全部资源,线程本身基本上不拥有系统资源,只拥有一点在运行中必不可少的信息. 进程和线程的关系: 1.一个线程只能属于一个进程,一个进程可以拥有多个线程,至少有一个线程.线程是操作系统可识别的最小执行和调度单位. 2.资源分配给进程,同一个进程的所有线程共享该进程的所有资源.同一进程中的多个线程共享代码段(代码和常量),数据段(全局变量和静态变量),扩展段(堆存储).每个线程拥有自己的栈段,栈段又叫运行时段,用来存放所有的局部变量和临时变量. 3.真正在CPU上运行的是线程. 4.线程在执行过程中,需要协作同步