Java多线程 博客分类: 多线程
线程这个词似乎听起来并不是很好理解,但是说到进程,我想大家应该不会陌生,我们在使用windows操作系统时,每当遇到某个软件运行出现卡顿的现象,我们最经常做的就是打开我们的任务管理器来结束相关进程,如下图中映像名称列中的是我的电脑目前正在运行的一部分进程,红线框出的是firefox浏览器的进程,
如果我的浏览器出现奔溃,就可以通过强制执行该进程,对进程有了一个形象上的认识之后,接下来说一下线程,线程可以简单的看成进程中在运行的程序所做的某一件事情,反过来可以理解成一个进程中可以有多个线程同时在工作,例如我们用下载工具(迅雷,电驴等)从网络上下载资源的时候,可以同时(这里给我们同时的感觉实际上是CPU在多个线程之间做着快速的切换,我们人眼看上去好像是同时在进行下载一样,当然多核的CPU除外)下载多个资源,每个下载的资源可以看成是一个线程,正在执行下载任务的迅雷则可以看成是一个进程,二者之间的关系与区别可以参考:http://blog.csdn.net/pyjfoot/article/details/7389389
Java中的多线程可以像上面所说的那样的在一个程序中同时运行多个任务,例如我们可以一边打印一些字符串,一边计算一些数的和值,并不用等到都打印完字符串后,才来计算和值,在Java中,创建线程有2种方式
1、将类声明为 Thread
的子类。该子类应重写 Thread
类的 run
方法。例如,计算大于某一规定值的质数的线程可以写成:
class PrimeThread extends Thread { long minPrime; PrimeThread(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime } }
下列代码会创建并启动一个线程:
PrimeThread p = new PrimeThread(143); p.start();
2、声明实现 Runnable
接口的类,并实现run()方法
class PrimeThread implements Runnable { long minPrime; PrimeThread(long minPrime) { this.minPrime = minPrime; } public void run() { // compute primes larger than minPrime } }
下列代码会创建并启动一个线程:
PrimeRun p = new PrimeRun(143); new Thread(p).start();
下面简单给出一个多线程的例子:
public class ThreadDemo { public static void main(String[] args) { // 创建好一个线程 Demo d = new Demo(); d.start(); //并不一定立即执行,要看此时该线程是否已经获得CPU资源,如果没有,则处于就绪状态 // d.run(); //仅仅是对象的调用方法,而线程创建了,并没有运行,相当于简单的运行了类的某个方法 for (int i = 0; i < 500; i++) { System.out.println("main --- " + i); } } } class Demo extends Thread { public void run() { for (int i = 0; i < 500; i++) System.out.println("demo run --- " + i); } }
由于结果较长,这里截取交替运行的一部分
可以看出2个线程在交替的打印信息
上一篇: C宏定义中#和##
下一篇: leetcode算法练习【73】矩阵置零