Java多线程

1、概念:线程与进程

以下概念引自百度百科词条——多线程
每个正在系统上运行的程序都是一个进程。每个进程包含一到多个线程。进程也可能是整个程序或者是部分程序的动态执行。线程是一组指令的集合,或者是程序的特殊段,它可以在程序里独立执行。也可以把它理解为代码运行的上下文。所以线程基本上是轻量级的进程,它负责在单个程序里执行多任务。通常由操作系统负责多个线程的调度和执行。
线程是程序中一个单一的顺序控制流程.在单个程序中同时运行多个线程完成不同的工作,称为多线程.
线程和进程的区别在于,子进程和父进程有不同的代码和数据空间,而多个线程则共享数据空间,每个线程有自己的执行堆栈程序计数器为其执行上下文.多线程主要是为了节约CPU时间,发挥利用,根据具体情况而定. 线程的运行中需要使用计算机的内存资源和CPU。

2、多线程创建方法

2.1 实现Runnable接口

        Runnable接口代码如下:

1 public interface Runnable{
2 
3 void run();
4 
5 }
View Code

 利用Runnable接口实现多线程的方法如下:

(1)实现Runnable接口

  

 1 public class ThreadDemo implements Runnable{
 2 
 3 //
 4 //other code
 5 //
 6 
 7 public void run(){
 8 
 9 //do something
10 
11 }
12 
13 }
View Code

 (2)创建对象

ThreadDemo td=new ThreadDemo();

(3)创建一个Thread对象

Thread tr=new Thread(td);

(4)启动线程

tr.start()

 

 

2.2 实现Callable接口

2.3 继承Thread类

3、多线程同步

3.1 Lock/Condition

3.2 Syschronized

3.3阻塞队列

posted on 2014-05-27 16:15  hadoop-yang  阅读(226)  评论(0)    收藏  举报