线程的理解
- 单线程和多线程的理解
单线程如同只雇佣一个服务员的餐厅,他必须做完一件事情之后,才可以做下一件事情.
多线程如同雇佣多个服务员的餐厅,他们可以同时进行着多件事情.
- 进程和线程的区别
几乎所有操作系统都支持进程的概念,所有运行中的任务都对应一个进程。当一个程序进入内存运行,即变成一个进程。进程是处于运行过程中的程序,并且具有一定独立功能,进程是系统进行资源分配和调度的一个独立单位。
进程包含三个特性:
(1) 独立性:进程是系统中独立存在的实体,它拥有自己独立的资源,每一个进程都拥有自己私有的地址空间。在没有经过进程本身允许的情况下,一个用户进程不可以直接访问其他进程的地址空间。
(2) 动态性:进程和程序的区别在于,程序只是一个静态的指令集合,而进程是一个正在系统中活动的指令集合。在进程中加入了时间的概念。进程具有自己的生命周期和各种不同的状态,这些概念在程序中是不具备的。
(3) 并发性:多个进程可以在单个处理器上并发执行,多个进程之间不会相互影响。
多线程扩展了多进程的概念,使得同一个进程可以同时并发处理多个任务。线程也被称为轻量级进程,线程是进程的执行单元。就像进程在操作系统中的地位一样,线程在程序中是独立的、并发的执行流。
线程可以拥有自己的堆栈、自己的程序计数器和自己的局部变量,但不再拥有系统资源,它与父进程的其他线程共享该进程所拥有的全部资源。
多线程的优点:
(1) 进程间不能共享内存,但线程之间共享内存非常容易
(2) 系统创建进程,需要为进程分配系统资源,但创建线程则代价小得多,因此使用多线程来实现多任务并发比多进程的效率高。
(3) Java语言内置多线程功能支持,而不是单纯地作为底层操作系统的调度方式,从而简化了java的多线程编程。