并发编程2:新建线程的几种方式

在java中,通常有以下几种方式新建线程

  • 继承Thread类,重写run方法
  • 实现Runnable接口
  • 实现callable接口
  • FutureTask封装callable接口

因为在java中,我们推荐的是接口编程(主要是因为java单继承却可以实现多接口),因此在前两种实现方式中,我们推荐用接口的方式。

但是在实际开发过程中,要求开发工程师在需要创建线程的情况下,统一采用jdk提供的线程工具类。

常用的三种如下:

//缓存线程池
ExecutorService cachedThreadPool = Executors.newCachedThreadPool();

//固定大小线程池
ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10);

//单个线程线程池
ExecutorService singleThread = Executors.newSingleThreadExecutor();

其中,ExecutorService提交到线程池执行的方式有两种:

  • execute:提交的Runnable执行无返回值
  • submit:提交的Callable<T> 执行有返回值,返回值类型为泛型类型

jdk还提供了定时任务的线程池:

	ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(10);

	scheduledThreadPool.scheduleAtFixedRate(new Runnable() {
		@Override
		public void run() {
			// TODO
		}
	// 延迟10秒后,以2分钟/次的时间间隔定时执行
	}, 10, 2, TimeUnit.MINUTES);

猜你喜欢

转载自blog.csdn.net/licwzy/article/details/88044043