我打算在我的

Java代码中使用线程优先级.

应用程序应在我的

Linux系统上运行:

>uname -a

Linux 3.0.0-15-generic #26-Ubuntu SMP x86_64 x86_64 x86_64 GNU/Linux

>java -version

java version "1.6.0_23"

OpenJDK Runtime Environment (IcedTea6 1.11pre) (6b23~pre11-0ubuntu1.11.10.1)

OpenJDK 64-Bit Server VM (build 20.0-b11, mixed mode)

在Web上阅读完之后,我现在使用以下命令启动我的测试应用程序:

sudo java -XX:+UseThreadPriorities -XX:ThreadPriorityPolicy=1 -jar ThreadPriorityTest.jar

测试应用程序包含以下两个类:

package ch.mypackage;

public class CountingRunnable implements Runnable{

private long count=0;

private boolean goOn=true;

public long getCount() {

return count;

}

public void stop(){

goOn=false;

}

public void run() {

for(long iteration=0;goOn&&iteration

++count;

}

}

}

package ch.mypackage;

public class PriorizedCountingThreads {

private static final int NUM_MILLIS_TO_COUNT_FOR = 1*60*1000;

private static CountingRunnable[] runnables;

private static Thread[] threads;

/**

* @param args

*/

public static void main(String[] args) {

Thread.currentThread().setPriority(Thread.MAX_PRIORITY);

System.out.println("MIN_PRIORITY: "+Thread.MIN_PRIORITY);

System.out.println("MAX_PRIORITY: "+Thread.MAX_PRIORITY);

int numPriorityLevels=(Thread.MAX_PRIORITY-Thread.MIN_PRIORITY)+1;

init(numPriorityLevels);

startThreads();

try {

Thread.sleep(NUM_MILLIS_TO_COUNT_FOR);

} catch (InterruptedException e) {

e.printStackTrace();

}

stopRunnables();

printCounts();

}

private static void printCounts() {

for(int i=0;i

System.out.println(threads[i].getName()+" has priority: "+threads[i].getPriority()+" and count:"+runnables[i].getCount());

}

}

private static void stopRunnables() {

for(int i=0;i

runnables[i].stop();

}

}

private static void startThreads() {

for(int i=0;i

threads[i].start();

}

}

private static void init(int numPriorityLevels) {

runnables=new CountingRunnable[numPriorityLevels];

threads=new Thread[runnables.length];

for(int i=0;i

int priority=i+1;

runnables[i]=new CountingRunnable();

threads[i]=new Thread(runnables[i]);

threads[i].setPriority(priority);

threads[i].setName("PriorityThread_"+priority);

}

}

}

如果我让程序计数一分钟(NUM_MILLIS_TO_COUNT_FOR = 1 * 60 * 1000),那么我得到以下输出:

MIN_PRIORITY: 1

MAX_PRIORITY: 10

PriorityThread_1 has priority: 1 and count:12658044343

PriorityThread_2 has priority: 2 and count:19008431582

PriorityThread_3 has priority: 3 and count:30618946099

PriorityThread_4 has priority: 4 and count:34408365142

PriorityThread_5 has priority: 5 and count:36694025023

PriorityThread_6 has priority: 6 and count:40493710165

PriorityThread_7 has priority: 7 and count:42826305342

PriorityThread_8 has priority: 8 and count:42203891414

PriorityThread_9 has priority: 9 and count:43128747383

PriorityThread_10 has priority: 10 and count:43416371500

根据这一输出,优先事项似乎具有预期的影响!

但是如果我使用“jstack”或“kill -s QUIT”生成一个线程转储,那么我得到以下输出,这意味着每条线都具有相同的优先级(prio = 10):

"PriorityThread_10" prio=10 tid=0x00007ff7e406f800 nid=0x12e6 runnable [0x00007ff7e2562000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_9" prio=10 tid=0x00007ff7e406d800 nid=0x12e5 runnable [0x00007ff7e2663000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_8" prio=10 tid=0x00007ff7e406b000 nid=0x12e4 runnable [0x00007ff7e2764000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_7" prio=10 tid=0x00007ff7e4069000 nid=0x12e3 runnable [0x00007ff7e2865000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_6" prio=10 tid=0x00007ff7e4067000 nid=0x12e2 runnable [0x00007ff7e2966000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_5" prio=10 tid=0x00007ff7e4065000 nid=0x12e1 runnable [0x00007ff7e2a67000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_4" prio=10 tid=0x00007ff7e4063000 nid=0x12e0 runnable [0x00007ff7e2b68000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_3" prio=10 tid=0x00007ff7e4061000 nid=0x12df runnable [0x00007ff7e2c69000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_2" prio=10 tid=0x00007ff7e405d000 nid=0x12de runnable [0x00007ff7e2d6a000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

"PriorityThread_1" prio=10 tid=0x00007ff7e4049800 nid=0x12dd runnable [0x00007ff7e2e6b000]

java.lang.Thread.State: RUNNABLE

at ch.mypackage.CountingRunnable.run(CountingRunnable.java:17)

at java.lang.Thread.run(Thread.java:679)

如果我在Windows机器上执行相同的操作,根据我找到的优先级映射here,prio值是正确的值.

那么,这是jstack中的一个错误,还是我做错了什么?

如果我执行“top | grep java”,我会得到以下内容:

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

3394 root 20 0 4444m 15m 8376 S 789 0.1 0:47.52 java

这意味着主线程的优先级为20,而“top -H | grep java”会产生以下输出:

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND

3457 root 15 -5 4444m 15m 8384 R 99 0.1 0:08.60 java

3456 root 16 -4 4444m 15m 8384 R 97 0.1 0:08.41 java

3455 root 17 -3 4444m 15m 8384 R 93 0.1 0:08.42 java

3454 root 18 -2 4444m 15m 8384 R 97 0.1 0:08.27 java

3453 root 19 -1 4444m 15m 8384 R 97 0.1 0:07.50 java

3452 root 20 0 4444m 15m 8384 R 51 0.1 0:07.44 java

3451 root 21 1 4444m 15m 8384 R 35 0.1 0:04.83 java

3450 root 22 2 4444m 15m 8384 R 99 0.1 0:04.78 java

3449 root 23 3 4444m 15m 8384 R 95 0.1 0:07.47 java

3448 root 24 4 4444m 15m 8384 R 18 0.1 0:02.85 java

这表明java线程优先级确实影响了OS线程的优先级.

但是jstack在prio = 10中的值是10?

它只是一个任意值吗?

linux下java转储线程_Java线程转储prio值与linux上的真实线程优先级不对应?相关推荐

  1. Linux java集成安装环境,Linux下Java环境安装

    本节主要讲解Linux(Centos 6.5)下Java环境的安装 1. 卸载机器上默认安装的JDK 在Linux环境下一般会默认安装jdk,为了自己项目的开发部署,一般情况要重新装jdk,而且自己装 ...

  2. linux下Java环境的配置

    linux下Java环境的配置 一. 下载jdk5.0 for linux 到sun的主页 [url]http://java.sun.com/j2se/1.5.0/download.jsp[/url] ...

  3. Linux下java/bin目录下的命令集合

    Linux下JAVA命令(1.7.0_79) 命令 详解 参数列表 示例 重要程度 资料 appletviewer Java applet 浏览器.appletviewer 命令可在脱离万维网浏览器环 ...

  4. Linux下Java Font 中文字体不显示

    为什么80%的码农都做不了架构师?>>>    linux系统中jre不支持字体解决方法 Linux下Java中文字体不显示 https://blog.csdn.net/kenera ...

  5. Linux下Java开发环境的搭建Tomcat6+jdk6+eclipse3.5.2+Myeclipse9.0+mysql5.1.47

    Tomcat6+jdk6+eclipse3.5.2+Myeclipse9.0+mysql5.1.47 1.JDK的安装:usr/java/jdk1.6.0_25 下载:jdk-6u25-linux-i ...

  6. linux下java.lang.NoClassDefFoundError: org/bouncycastle/jce/provider/BouncyCastleProvider解决方法

    linux下java.lang.NoClassDefFoundError: org/bouncycastle/jce/provider/BouncyCastleProvider解决方法 参考文章: ( ...

  7. linux下java调用matlab程序,linux_java调用windows_matlab程序

    0 说明 本文为研究java和matlab的混合编程,进行了详细的测试和探索,以解决linux环境下java程序调用matlab程序的一个应用. linux端的环境 :(运行java程序并调用wind ...

  8. linux java 工具_Linux运维知识之linux下java版本管理工具jenv使用介绍

    本文主要向大家介绍了Linux运维知识之linux下java版本管理工具jenv使用介绍,通过具体的内容向大家展现,希望对大家学习Linux运维知识有所帮助. 不同的项目使用的java版本不同,每次切 ...

  9. linux下java程序乱码,解决linux下java程序(例如applet)中文乱码问题

    解决linux下java程序(例如applet)中文乱码问题 平台:Mandriva 2006.0 将Windows下的字体文件simsun.ttc拷贝到/usr/share/fonts/zh_CN, ...

  10. java 本地 mq_windows、linux下java连接本地MQ队列实现输入(二)

    windows.linux下java连接本地MQ队列实现输入(二),上一篇文章环境为windows,这一篇将说一下linux环境下java连接本地队列实现输入输出,其实大同小异,但是八戒在这里有很多心 ...

最新文章

  1. C#各种加密算法的研究
  2. html中函数传递多个值,JavaScript 实战开发经验!函数多参数传参技巧
  3. Python3 写JSON数据到文件(多行格式化版)
  4. MySQL的启动和停止
  5. golang 常用配置
  6. 算法设计与分析 —— 排列问题
  7. Android中Toast的简单使用
  8. word文档分栏怎么设置
  9. 五一劳动节,讲讲NEO智能合约的调试
  10. 最小公倍数用c语言,如何用C语言求最小公倍数。。。
  11. win10 电脑自带的便签在哪里
  12. 饭谈:盘点六种错误的技术问题提问
  13. (Modern Family S01E01) Part 4  PhilClaire  Luke射Alex / Haley邀请Dylan
  14. Centos7安裝GitHub
  15. 使用git提交代码到仓库报错总结
  16. Android设备root及xposedPrivacy的安装
  17. 软件设计师---钉子户
  18. 亚马逊云科技的AI新引擎,如何助力企业应对“乌卡时代”?
  19. 中国移动物联网连接规模超6000万
  20. 用Python学《微积分B》(有理式与简单无理式积分套路)

热门文章

  1. Python学习入门基础:文件读写操作、模块和包、异常
  2. Javascript——进阶(事件、数组操作、字符串操作、定时器)
  3. python3生成器类题目易错写法
  4. Python中的互斥锁和join的应用
  5. 漫步最优化二十四——二分搜索
  6. 有什么软件可以测试手机gprs,哪个软件可通过GPRS发信息啊?
  7. 一体化服务器和oracle集群,4种Oracle DBaaS部署模式,你在使用哪一种?
  8. HMM隐马尔科夫模型浅析
  9. SQL避免IN 和 NOT IN
  10. 数据积分-牛顿科茨法与高斯勒让德法对比及示例