为什么需要多线程? 换个词你可能听过,多任务。
不管是在Linux还是Windows操作系统上,都支持在同一个时刻运行多个程序。每个程序就是我们常说的进程,而一个进程中包含多个线程。
一、什么叫多线程
在较低层次上扩展了多任务的概念:一个程序同时执行多个任务。通常,每个任务称为一个线程,可以同时运行一个以上线程的程序称为多线程程序。
简而言之:每个运行的程序是一个进程,进程中要处理的每个子任务是一个个线程,使用多线程就是为了执行多个任务。
二、多进程与多线程的区别
其实也就是进程与线程的区别,本质的区别在于每个进程拥有自己的一整套变量,而线程则是共享数据。多进程间与多线程间的通信方式也不同,共享变量使线程之间的通信比进程间之间的通信更有效,更容易。此外,在有些操作系统中,与进程相比较,线程更“轻量级”,创建、撤销一个线程比启动一个新进程的开销要小得多。
三、多线程带来的问题
1、程序执行结果不可预见
多线程环境下,在对共享变量操作时,存在当前线程的操作逻辑被其它线程打断,其它线程的操作无效。产生这种情况的本质是多线程的抢占式线程调度策略,当前线程的逻辑还没执行完,就被剥夺的时间片。下个时刻被另外一个线程抢到时间片,该线程修改了共享变量。再下个时刻,之前的线程拿到时间片继续执行。但它以为共享变量没有被改变,继续按最初的共享变量值执行下去,这样会擦除后一个线程所做的更新。所以多线程不加同步机制会随机出错。
2、如何解决
需要线程同步机制
有哪些线程同步的方式:
-
使用Lock对象配合condition条件对象使用,包括读/写锁
-
synchronized关键字
-
保证可见性,volatile域和final变量
-
原子类,使用高效的机器指令(而不是使用锁)
-
使用队列数据结构