线程和进程理不清,剪还乱,其实它俩剪不断······进程:系统进行资源分配和调度的基本单位。可以从下边二个角度对比分析:
第一:1个进程可以有多个线程;1个线程必须属于一个进程。
第二:进程是分配资源;线程是共享资源。线程是最小工作单位。
上图清晰明了的点名线程和进程的关系,接下来咱们进入多线程。Java语言的JVM允许程序运行多个线程,它的实现方式有两种,先看一个简单例子:一种是继承java.lang.Thread类,另外一种是实现Runable接口。先看继承Thread类的一个简单例子:
<span style="font-family:SimSun;font-size:18px;"><span style="font-family:SimSun;font-size:18px;">/**
* @author xx 继承Thread类,直接调用run方法
* */
class hello extends Thread {
public hello() {
}
public hello(String name) {
this.name = name;
}
public void run() {
for (int i = 0; i < 5; i++) {
System.out.println(name + "运行 " + i);
}
}
public static void main(String[] args) {
hello h1=new hello("A");
hello h2=new hello("B");
h1.start();
h2.start();
}
private String name;
}</span></span>
注意:这里调用的是start()方法,但是实际上调用的还是run()方法的主体。我尝试把main函数中的h1.start()方法直接写成h1.run()方法,发现直接执行run方法,执行结果完全是很顺序的。如果是h1.start()方法,执行结果是无序的,因为需要用到CPU资源,所以每次的结果都是不一样(无序)的。那为什么要用start方法启动呢?
这个thread.start()方法很重要,第一它是开启子线程,第二然后它调用子线程的run方法。切不可new出子线程对象thread,然后直接调用子线程的run方法thread.run(),这样相当于没有开启子线程,你又如何调用它的run呢?所以说,要想启动一个多线程,必须调用它的start()方法。
其实Thread也是实现Runnable接口的,它们的区别是:如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。下边是继承Thred实例以及运行效果:
package com.xx.Thread;
public class HelloThread extends Thread {
private int count = 5;
public void run() {
for (int i = 0; i < 7; i++) {
if (count > 0) {
System.out.println("count= " + count--);
}
}
}
public static void main(String[] args) {
HelloThread h1 = new HelloThread();
HelloThread h2 = new HelloThread();
HelloThread h3 = new HelloThread();
h1.start();
h2.start();
h3.start();
}
}
运行结果如下:
如果这个是一个买票系统的话,如果count表示的是车票的数量的话,说明并没有实现资源的共享。下边我们换为Runnable接口:
package com.xx.Thread;
class HelloRunnable implements Runnable {
private int ticket = 5; //5张票
public void run() {
for (int i = 0; i <= 20; i++) {
if (this.ticket > 0) {
System.out.println(Thread.currentThread().getName() + "正在卖票" + this.ticket--);
}
}
}
}
package com.xx.Thread;
public class TestRunnable {
public static void main(String[] args) {
HelloRunnable helloRunnable = new HelloRunnable();
new Thread(helloRunnable, "1号窗口").start();
new Thread(helloRunnable, "2号窗口").start();
new Thread(helloRunnable, "3号窗口").start();
}
}
执行结果: