详细内容

Java 线程优先级

Thread 类中,使用如下属性来代表优先级。private int priority;

我们可以通过 setPriority(int newPriority) 来设置新的优先级,通过 getPriority() 来获取线程的优先级。

有些资料通过下面的例子就得出了一个结论:Java 线程默认优先级是 5。public static void main(String[] args) {

Thread thread = new Thread();

System.out.println(thread.getPriority());

}

// 打印结果:5

其实这是大错特错的,只是看到了表面,看看下面的例子,我们把当前线程的优先级改为 4,发现子线程 thread 的优先级也是 4。public static void main(String[] args) {

Thread.currentThread().setPriority(4);

Thread thread = new Thread();

System.out.println(thread.getPriority());

}

// 打印结果:4

这啪啪啪打脸了,如果是线程默认优先级是 5,我们新创建的 thread 线程,没设置优先级,理应是 5,但实际是 4。我们看看 Thread 初始化 priority 的源代码。Thread parent = currentThread();

this.priority = parent.getPriority();

原来,线程默认的优先级是继承父线程的优先级,上面例子我们把父线程的优先级设置为 4,所以导致子线程的优先级也变成 4。

严谨一点说,子线程默认优先级和父线程一样,Java 主线程默认的优先级是 5。

Java 中定义了 3 种优先级,分别是最低优先级(1)、正常优先级(5)、最高优先级(10),代码如下所示。Java 优先级范围是 [1, 10],设置其他数字的优先级都会抛出 IllegalArgumentException 异常。/**

* The minimum priority that a thread can have.

*/

public final static int MIN_PRIORITY = 1;

/**

* The default priority that is assigned to a thread.

*/

public final static int NORM_PRIORITY = 5;

/**

* The maximum priority that a thread can have.

*/

public final static int MAX_PRIORITY = 10;

接下来说说线程优先级的作用。先看下面代码,代码逻辑是创建了 3000 个线程,分别是: 1000 个优先级为 1 的线程, 1000 个优先级为 5 的线程,1000 个优先级为 10 的线程。用 minTimes 来记录 1000 个 MIN_PRIORITY 线程运行时时间戳之和,用 normTimes 来记录 1000 个 NORM_PRIORITY 线程运行时时间戳之和,用 maxTimes 来记录 1000 个 MAX_PRIORITY 线程运行时时间戳之和。通过统计每个优先级的运行的时间戳之和,值越小代表的就是越优先执行。我们运行看看。public class TestPriority {

static AtomicLong minTimes = new AtomicLong(0);

static AtomicLong normTimes = new AtomicLong(0);

static AtomicLong maxTimes = new AtomicLong(0);

public static void main(String[] args) {

List minThreadList = new ArrayList<>();

List normThreadList = new ArrayList<>();

List maxThreadList = new ArrayList<>();

int count = 1000;

for (int i = 0; i < count; i++) {

MyThread myThread = new MyThread("min----" + i);

myThread.setPriority(Thread.MIN_PRIORITY);

minThreadList.add(myThread);

}

for (int i = 0; i < count; i++) {

MyThread myThread = new MyThread("norm---" + i);

myThread.setPriority(Thread.NORM_PRIORITY);

normThreadList.add(myThread);

}

for (int i = 0; i < count; i++) {

MyThread myThread = new MyThread("max----" + i);

myThread.setPriority(Thread.MAX_PRIORITY);

maxThreadList.add(myThread);

}

for (int i = 0; i < count; i++) {

maxThreadList.get(i).start();

normThreadList.get(i).start();

minThreadList.get(i).start();

}

try {

Thread.sleep(3000);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("maxPriority 统计:" + maxTimes.get());

System.out.println("normPriority 统计:" + normTimes.get());

System.out.println("minPriority 统计:" + minTimes.get());

System.out.println("普通优先级与最高优先级相差时间:" + (normTimes.get() - maxTimes.get()) + "ms");

System.out.println("最低优先级与普通优先级相差时间:" + (minTimes.get() - normTimes.get()) + "ms");

}

static class MyThread extends Thread {

public MyThread(String name) {

super(name);

}

@Override

public void run() {

System.out.println(this.getName() + " priority: " + this.getPriority());

switch (this.getPriority()) {

case Thread.MAX_PRIORITY :

maxTimes.getAndAdd(System.currentTimeMillis());

break;

case Thread.NORM_PRIORITY :

normTimes.getAndAdd(System.currentTimeMillis());

break;

case Thread.MIN_PRIORITY :

minTimes.getAndAdd(System.currentTimeMillis());

break;

default:

break;

}

}

}

}

执行结果如下:# 第一部分

max----0 priority: 10

norm---0 priority: 5

max----1 priority: 10

max----2 priority: 10

norm---2 priority: 5

min----4 priority: 1

.......

max----899 priority: 10

min----912 priority: 1

min----847 priority: 5

min----883 priority: 1

# 第二部分

maxPriority 统计:1568986695523243

normPriority 统计:1568986695526080

minPriority 统计:1568986695545414

普通优先级与最高优先级相差时间:2837ms

最低优先级与普通优先级相差时间:19334ms

我们一起来分析一下结果。先看看第一部分,最开始执行的线程高优先级、普通优先级、低优先级都有,最后执行的线程也都有各个优先级的,这说明了:优先级高的线程不代表一定比优先级低的线程优先执行。也可以换另一种说法:代码执行顺序跟线程的优先级无关。看看第二部分的结果,我们可以发现最高优先级的 1000 个线程执行时间戳之和最小,而最低优先级的 1000 个线程执行时间戳之和最大,因此可以得知:一批高优先级的线程会比一批低优先级的线程优先执行,即高优先级的线程大概率比低优先的线程优先获得 CPU 资源。

各操作系统中真有 10 个线程等级么?

Java 作为跨平台语言,线程有 10 个等级,但是映射到不同操作系统的线程优先级值不一样。接下来教大家怎么在 OpenJDK 源码中查各个操作系统中线程优先级映射的值。

看到 Thread 源代码,设置线程优先级最终调用了本地方法 setPriority0();private native void setPriority0(int newPriority);

接着我们在 OpenJDK 的 Thread.c 代码中找到 setPriority0() 对应的方法 JVM_SetThreadPriority;static JNINativeMethod methods[] = {

...

{"setPriority0", "(I)V", (void *)&JVM_SetThreadPriority},

...};

我们根据 JVM_SetThreadPriority 找到 jvm.cpp 中对应的代码段;JVM_ENTRY(void, JVM_SetThreadPriority(JNIEnv* env, jobject jthread, jint prio))

JVMWrapper("JVM_SetThreadPriority");

// Ensure that the C++ Thread and OSThread structures aren't freed before we operate

MutexLocker ml(Threads_lock);

oop java_thread = JNIHandles::resolve_non_null(jthread);

java_lang_Thread::set_priority(java_thread, (ThreadPriority)prio);

JavaThread* thr = java_lang_Thread::thread(java_thread);

if (thr != NULL) { // Thread not yet started; priority pushed down when it is

Thread::set_priority(thr, (ThreadPriority)prio);

}

JVM_END

根据第 3 步中的代码,我们可以发现关键是 java_lang_Thread::set_Priority() 这段代码,继续找 thread.cpp 代码中的 set_Priority() 方法;void Thread::set_priority(Thread* thread, ThreadPriority priority) {

trace("set priority", thread);

debug_only(check_for_dangling_thread_pointer(thread);)

// Can return an error!

(void)os::set_priority(thread, priority);

}

java最高线程优先级是,Java线程优先级相关推荐

  1. Java多线程系列--“基础篇”10之 线程优先级和守护线程

    概要 本章,会对守护线程和线程优先级进行介绍.涉及到的内容包括: 1. 线程优先级的介绍 2. 线程优先级的示例 3. 守护线程的示例 转载请注明出处:http://www.cnblogs.com/s ...

  2. Java 多线程(三) 线程的生命周期及优先级

    Java 多线程(三) 线程的生命周期及优先级 线程的生命周期 线程的生命周期:一个线程从创建到消亡的过程. 如下图,表示线程生命周期中的各个状态: 线程的生命周期可以分为四个状态: 1.创建状态: ...

  3. java中一个线程最小优先数_Java线程的优先级

    Java线程可以有优先级的设定,高优先级的线程比低优先级的线程有更高的几率得到执行(不完全正确,请参考下面的"线程优先级的问题"). 记住当线程的优先级没有指定时,所有线程都携带普 ...

  4. java判断优先级代码,Java如何查看线程的优先级?

    在Java编程中,如何查看线程的优先级? 以下示例演示如何使用Thread类的getPriority()方法检查线程的优先级. package com.yiibai; public class Thr ...

  5. Java基础篇:什么是线程优先级?

    线程优先级被线程调度用来判定何时每个线程允许运行.理论上,优先级高的线程比优先级低的线程获得更多的CPU时间.实际上,线程获得的CPU时间通常由包括优先级在内的多个因素决定. 一个优先级高的线程自然比 ...

  6. JAVA中的多线程(八):线程的优先级和yield方法

    JAVA中的多线程(八):线程的优先级和yield方法 优先级代表着抢资源的频率 所有线程默认优先级是5 yield()临时释放线程的执行权 1 class Demo implements Runna ...

  7. Java性能-线程和同步-JVM线程优化和线程优先级

    线程和同步-JVM线程优化 优化线程栈大小 每个线程都有一个原生栈,操作系统会在这里存储线程的调用栈信息,如果空间不足可以通过调整线程使用的内存. 64位机器默认原生栈大小1MB 如果将线程栈设置的非 ...

  8. What is Java thread priority? 什么是java线程优先级

    就一个小程序,运行一次输出结果不一样,这是因为线程调度方法不能确定,取决你当前操作系统的进程,线程调度优先级. 所以要想线程按一定的顺序运行,哪么只能选择Synchronized 互斥(对象锁)和 w ...

  9. Java线程的调度(线程的优先级、线程睡眠、线程让步、线程插队)

    线程的优先级 : Java语言中线程有优先级,优先级高的线程会获得较多的运行机会. 当程序中有多个线程存在的时候,线程和线程之间的关系并非是平等的. Java语言中线程的优先级用整数表示,取值范围是1 ...

最新文章

  1. Linux C SQLite3 编程
  2. ARP协议全面实战手册——Wireshark的安装第一更
  3. HIVE 插入中文分区值的问题
  4. nginx 集群部署_如何备份和还原您的Kubernetes集群资源和持久卷?
  5. VMware虚拟机上安装Linux系统
  6. js实现鼠标拖拽功能基本思路
  7. 类固醇上的Java:5种超级有用的JIT优化技术
  8. 2021届定远三中高考成绩查询,定远各中学高考喜报!
  9. 超大容量文本的单词统计(洛谷P1308题题解,Java语言描述)
  10. Java实现 给定三个 int 变量, 求其中的最大值和最小值
  11. 02-04 Python库-faker
  12. [iOS]ARC和MRC下混编
  13. C#知识点总结系列:2、C#中IDisposable和IEnumerable、IEnumerator
  14. 神经网络预测模型基本原理与编程实现
  15. 一个好用的智能抠图网站
  16. zblog自动采集伪原创站群文章更新器
  17. 思科模拟器 --- 扩展IP访问控制列表配置
  18. Pascal VOC转COCO格式亲测有效
  19. 图灵机器人接口实现自动回复(web版)
  20. 自制p站小姐姐图片返回api.

热门文章

  1. 360刷机教程 360手机线刷 360手机救砖 360手机刷机Root Twrp 360手机刷机包 360手机驱动
  2. 纳指万点!苹果微软市值1.5万亿美元,腾讯阿里能否破万亿?
  3. mysql 获取农历年份_php下实现农历日历的代码
  4. 微信小程序分包加载,分包加载的优势
  5. 程序员转正述职报告_2020程序员转正工作总结5篇精选范文
  6. 是德示波器软件,Keysight示波器上位机软件NS-Scope
  7. python实现批量修改图片尺寸和图片名称
  8. matlab 幂法,数值分析试验幂法与反幂法matlab.doc
  9. JS Web API
  10. PHP接口上传文件图片详解