第一节 进程和线程
1.1 进程和线程
l 程序Program
n 程序是一段静态的代码,它是应用程序执行的蓝本
l 进程Process
n 进程是指一种正在运行的程序,有自己的地址空间
l 进程的特点
n 动态性
n 并发性
n 独立性
n 并发和并行的区别
u 并行:多个CPU同时执行多个任务
u 并发:一个CPU(采用时间片)同时执行多个任务
- 线程Thread
- 进程内部的一个执行单元,它是程序中一个单一的顺序控制流程。
- 线程又被称为轻量级进程(lightweight process)
- 如果在一个进程中同时运行了多个线程,用来完成不同的工作,则称之为多线程
- 线程特点
- 轻量级进程
- 独立调度的基本单位
- 共享进程资源
区别 |
进程 |
线程 |
根本区别 |
作为资源分配的单位 |
调度和执行的单位 |
开 销 |
每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销。 |
线程可以看成时轻量级的进程,同一类线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小。 |
所处环境 |
在操作系统中能同时运行多个任务(程序) |
在同一应用程序中有多个顺序流同时执行 |
分配内存 |
系统在运行的时候会为每个进程分配不同的内存区域 |
除了CPU外,不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源 |
包含关系 |
没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的。 |
线程是进程的一部分,所以线程有的时候被称为是轻权进程或者轻量级进程。 |
1.2线程定义和创建1:继承Thread类
- Thread类是Java提供的线程顶级类,继承Thread类可快速定义线程。
public class TortoiseThread extends Thread { public class Test { |
- run() 线程体,线程要完成的任务
- start() 启动线程,线程进入就绪队列,等待获取CPU并执行
- 之前讲解的程序都是单线程的