java并发(2)-优先级,让步,后台线程
优先级
java中,线程是有不同的优先级,优先级高的,就会优先执行。
而优先级低的线程,并不是说不会执行,而是执行的频率会相对于优先级高的线程执行得少。
代码中我们可以通过以下方式获取线程的优先级
Thread.currentThread().getPriority();
并且可以通过以下方式设置线程的优先级
Thread.currentThread().setPriority(int priority);
其中int的参数就是线程优先级的数据,
其中API提供了三个
Thread.MAX_PRIORITY;//10
Thread.MIN_PRIORITY;//1
Thread.NORM_PRIORITY;//5
也就是说,一共有10个优先级。但是由于不同操作系统的线程优先级设计不同。为了程序的可移植,最好只使用上面提到的三个。
让步
让步的概念,上一个小节已经稍微有点提到了,就是yield()方法。其实它的真正作用是:给线程调度器一个暗示,告诉它自己的工作已经差不多了。可以让出CPU给其他线程了。当然,这仅仅只是一个暗示,并没有任何机制保证它会被采纳。其实也就是暗示相同优先级的其他线程可以运行罢了。
后台线程
后台线程就是指程序运行的时候在后台提供的一种通用服务的线程。而且有一个特点,当非后台线程结束的时候,程序就算结束了,这时候,后台线程也会被杀死。也就是说,只要有非后台线程还在运行,程序就不会结束。
如何创建后台线程
之前我们也说过,线程的创建普通的就有两种,一种就是实现Runnable,另一种就是继承Thread。这两种都是需要new一个Thread的。而new出来的那个Thread。在其运行之前,我们可以通过如下方式实现后台线程
Thread thread = new Thread();
thread.setDaemon(true);//设置成后台线程
thread.run();//然后才开始跑线程
那么问题来了,之前我们所说的Executor(执行器)该怎么让线程后台跑呢?
首先我们实现ThreadFactory,如下:
class MyDaemonThreadFactory implements ThreadFactory{
@Override
public Thread newThread(Runnable r) {
Thread thread = new Thread(r);
thread.setDaemon(true);
return thread;
}
}
从代码里面,我们可以看到,创新新线程的时候,已经设置为后台线程了。
之后就是在使用的时候,使用我们这个类,如下:
使用的方法和上一个小节的方式差不多,其实就是在创建ExecutorService的时候,将我们的这个类所为参数传进去。
ExecutorService exec = Executors.newCachedThreadPool(new MyDaemonThreadFactory());
//或者
ExecutorService exec = Executors.newFixedThreadPool(5, new MyDaemonThreadFactory());
//或者
ExecutorService exec = Executors.newSingleThreadExecutor(new MyDaemonThreadFactory());
如上,这样我们就是实现了使用Executor创建后台线程。
判断是否后台线程,可以使用
thread.isDaemon();
后面说一下,ThreadFactory,这个不仅仅可以设置为后台线程,也可以设置其他线程的属性哦,如优先级、名称。