在我们最开始学的程序中,都只有一个线程,即同一时刻之内做一件事,程序中的任务都是一个一个的顺序完成的。可很多时候我们面临的问题却是有多个任务同时进行的,这个时候就需要用到多线程。多线程就是java中内置的用来同时运行多个任务的机制。前面也提到过java的多线程只是用户视觉上的多线程,其实只是jvm把cpu资源的使用权在不同的线程之间快速地切换而已(多个cpu的电脑则不用切换,而是把不同的任务分给不同的cpu,实现了真正意义上的多线程),只是这个时间间隔足够的小使人感觉就像是在同时执行罢了。
在学习多线程之前必须明白什么是线程,区分程序、进程和线程。
程序是指一段静态的代码,他是应用软件执行的蓝本。
进程是程序一次动态的执行过程,包括加载静态代码、执行以及执行结束三个过程。
线程进程的一次更小的划分,一个进程可以产生多个不同的线程,形成多条执行线索,每个执行线索(线程)都有他创建、开始、中断、结束的生命周期。线程之间可以通过共享内存单元实现数据的共享、信息的沟通。
多线程的实现
1、创建Thread的子类来实现多线程
package com.mfs.test.thread;
public class ThreadTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
StringBuffer sb = new StringBuffer();
Windows win1 = new Windows("窗口一",sb);
Windows win2 = new Windows("窗口二",sb);
win1.start();
win2.start();
}
}
class Windows extends Thread{
private StringBuffer targets;
public Windows(String name,StringBuffer targets) {
setName(name);
this.targets = targets;
}
public void run() {
for(int i = 0;i < 3;i ++) {
targets.append(getName());
System.out.println("我是"+getName()+",StringBuffer是:"+targets);
Thread.yield(); //建议jvm在此处切换cpu的使用权,只是建议真正会不会这样做不一定
}
}
}
2、通过实现Runnable接口实现多线程
用多线程实现多个斐波纳契数列
package com.mfs.test.thread;
import java.text.DecimalFormat;
public class RunnableTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
for(int i = 0;i < 5;i ++) {
new Thread(new Run(10)).start();
}
}
}
class Run implements Runnable{
protected int countDown; //一个数列的元素个数
private static int taskCount = 0;
private final int id = taskCount++; //做线程的标识id
private double first = -1; //斐波纳契数列的”第负一“
private double second = 1; //第零个
private int count = 0;
public Run(int n) {
System.out.println("#"+id+"(Run Now),");
countDown = n;
}
private String status() {
return "#"+id+"id"+(++count)+"("+new DecimalFormat("0").format(first+second)+"),";
}
@Override
public void run() {
// TODO Auto-generated method stub
while(countDown-- >0) {
System.out.println(status());
double n = first;
first = second;
second = n + second;
Thread.yield();
}
}
}