Java多线程--线程优先级
2017-09-03 17:46
309 查看
在操作系统中,线程可以划分优先级,优先级较高的线程得到CPU资源较多,也就是CPU优先执行优先级较高的线程对象中的任务(其实并不是这样)。
在java中,线程的优先级用setPriority()方法就行,线程的优先级分为1-10这10个等级,如果小于1或大于10,则抛出异常throw new IllegalArgumentException(),默认是5。
[java] view
plain copy
public class MyThread1 extends Thread {
@Override
public void run() {
long startTime=System.currentTimeMillis();
long addResult=0;
for (int i = 0; i < 1000000; i++) {
new Random().nextInt();
addResult+=i;
}
long endTime=System.currentTimeMillis();
System.out.println("thread1 use time--->"+(endTime-startTime));
}
}
[java] view
plain copy
public class MyThread2 extends Thread {
@Override
public void run() {
long startTime=System.currentTimeMillis();
long addResult=0;
for (int i = 0; i < 1000000; i++) {
new Random().nextInt();
addResult+=i;
}
long endTime=System.currentTimeMillis();
System.out.println("thread2 use time--->"+(endTime-startTime));
}
}
[java] view
plain copy
public class MyThread{
public static void main(String[] args){
for (int i = 0; i < 5; i++) {
MyThread1 t1=new MyThread1();
t1.setPriority(10);
t1.start();
MyThread2 t2=new MyThread2();
t2.setPriority(1);
t2.start();
}
}
}
![](https://img-blog.csdn.net/20150719221202564?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
从结果中可以发现,也有thread2比thread1先执行完,也就验证了线程的优先级于代码执行顺序无关。
[java] view
plain copy
public class MyThread{
public static void main(String[] args){
for (int i = 0; i < 5; i++) {
MyThread1 t1=new MyThread1();
t1.setPriority(6);
t1.start();
MyThread2 t2=new MyThread2();
t2.setPriority(5);
t2.start();
}
}
![](https://img-blog.csdn.net/20150719222331442?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
如果我们把优先级设置近点的话,发现优先级较高的线程不一定没一次都执行完,线程的优先级与打印的顺序无关,不要将这两点的关系相关联,他们的关系是不确定性和随机性。
线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行。
在java中,线程的优先级用setPriority()方法就行,线程的优先级分为1-10这10个等级,如果小于1或大于10,则抛出异常throw new IllegalArgumentException(),默认是5。
[java] view
plain copy
public class MyThread1 extends Thread {
@Override
public void run() {
long startTime=System.currentTimeMillis();
long addResult=0;
for (int i = 0; i < 1000000; i++) {
new Random().nextInt();
addResult+=i;
}
long endTime=System.currentTimeMillis();
System.out.println("thread1 use time--->"+(endTime-startTime));
}
}
[java] view
plain copy
public class MyThread2 extends Thread {
@Override
public void run() {
long startTime=System.currentTimeMillis();
long addResult=0;
for (int i = 0; i < 1000000; i++) {
new Random().nextInt();
addResult+=i;
}
long endTime=System.currentTimeMillis();
System.out.println("thread2 use time--->"+(endTime-startTime));
}
}
[java] view
plain copy
public class MyThread{
public static void main(String[] args){
for (int i = 0; i < 5; i++) {
MyThread1 t1=new MyThread1();
t1.setPriority(10);
t1.start();
MyThread2 t2=new MyThread2();
t2.setPriority(1);
t2.start();
}
}
}
从结果中可以发现,也有thread2比thread1先执行完,也就验证了线程的优先级于代码执行顺序无关。
[java] view
plain copy
public class MyThread{
public static void main(String[] args){
for (int i = 0; i < 5; i++) {
MyThread1 t1=new MyThread1();
t1.setPriority(6);
t1.start();
MyThread2 t2=new MyThread2();
t2.setPriority(5);
t2.start();
}
}
如果我们把优先级设置近点的话,发现优先级较高的线程不一定没一次都执行完,线程的优先级与打印的顺序无关,不要将这两点的关系相关联,他们的关系是不确定性和随机性。
线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行。
相关文章推荐
- java多线程之线程的优先级
- Java 多线程(三) 线程的生命周期及优先级
- Java多线程-线程的调度(优先级)
- Java多线程-线程的调度(优先级)
- java多线程系列8-线程的优先级
- 三、java多线程核心技术(笔记)——线程的优先级
- Java多线程系列--“基础篇”10之 线程优先级和守护线程
- [疯狂Java]多线程:线程控制(join、daemon、sleep、yield、优先级)
- JAVA之旅(十五)——多线程的生产者和消费者,停止线程,守护线程,线程的优先级,setPriority设置优先级,yield临时停止
- Java 多线程(三) 线程的生命周期及优先级
- Java多线程(2)——线程状态,操作,优先级
- Java多线程系列--“基础篇”10之 线程优先级和守护线程
- Java多线程 小知识 守护线程(后台线程)setDaemon、join方法、优先级、yield方法
- Java 多线程(三) 线程的生命周期及优先级
- java 多线程系列基础篇(十)之线程优先级和守护线程
- JAVA之旅(十五)——多线程的生产者和消费者,停止线程,守护线程,线程的优先级,setPriority设置优先级,yield临时停止
- 玩转java多线程学习篇五 线程的优先级和守护线程
- java多线程之线程的优先级
- Java 多线程(三) 线程的生命周期及优先级
- 【java多线程与并发库】---传统java多线程<4> .线程状态及优先级