一、简单粗暴的线程

最原始的方式,当我们要并行的或者异步的执行一个任务的时候,我们会直接使用启动一个线程的方式,如下面所示:

复制代码
new Thread(new Runnable() {

    @Override public void run() { // TODO Auto-generated method stub  这里放你要执行的方法  }
}).start();
复制代码

 

但是像上面或者类似这种每次来都是用new 一个Thread出来的方式存在着很多的弊端,如下面:

  • 每次new Thread新建对象性能差;
  • 线程缺乏统一的管理,可以无限制新建线程,相互之间竞争,还可能占用过多系统资源导致死机或者OOM(Out of Memory);
  • 缺乏更多的功能,如定时执行、定期执行、线程中断等。

二、线程池

为了解决这些问题,Jdk1.5之后加入了java.util.concurrent包,这个包中主要介绍java中线程以及线程池的使用。为我们在开发中处理线程的问题提供了非常大的帮助。