多线程
线程与进程:
- 进程:进程是处于运行中的程序,是操作系统进行资源分配和调度的一个单位
- 线程:线程是进程的执行单元,当进程被创建时,主线程就被创建,可由主线程创建多个子线程
并发与并行
- 并发性:多个进程在单个处理器上并发执行,同一时刻只能有一条指令执行,多个进程指令被快速轮换执行
- 并行性:同一时刻有多条指令在多个处理器上执行
多进程与多线程
- 大部分操作系统支持多进程并发,常用抢占式多任务策略,也有共用式多任务,创建进程时系统分配独立内存空间,并分配大量资源,不同进程不能共享内存
- 多线程由一个进程创建,线程间可以共享:进程代码段、进程公有数据、进程内存,容易实现线程间相互通信
线程的创建方式(3种)
- 继承Thread类创建线程类
public class ThreadTest extends Thread {
private int i; //此i不能为多个线程共用,每个线程创建时有自己的i
public void run()//重写run()方法
{
for (; i < 100; i++)
{
System.out.println(this.getName() + "run:" + i);
//此处用this直接获得当前线程对象
}
}
public static void main(String[] args){
...
ThreadTest firstThread = new ThreadTest();
firstThread.start();
...
}
}
- 实现Runnable接口创建线程类
public class RunnableTest implements Runnable {
private int i;//此i为多个线程共用,实际是多个target共用
@Override
public void run()//重写run()方法
{
for (; i < 100; i++)
{
System.out.println(Thread.currentThread().getName() + " " + i);
//此处与(1)不同,不能用this.getName(),只能用Thread.currentThread().getName()
}
}
public static void main(String[] args)
{
...
RunnableTest rt = new RunnableTest();
//以Runnable实现类的对象作为Thread的target来创建Thread对象
new Thread(rt , "t1:").start();
...
}
}
Runnable对象仅仅作为Thread对象的target,Runnable实现类里包含的run()方法仅作为线程执行体,而实际的线程对象依然是Thread实例,只是该Thread线程负责执行其target的run()方法
- 使用Callable接口和Future接口创建线程类
Callable接口是Runnable接口的加强版,Runnable接口中的唯一方法run()使用时被Thread类包装成线程执行体,不能有返回值,于是Java 5 新增的Callable接口提供了call() 方法,比run()功能更强大:
- call()方法可以有返回值(通过Future接口实现)
- 可以声明抛出异常
一般推荐采用实现Runnable、Callable接口的方式来创建多线程,优点是可以有返回值,还可以继承其他类。