如何设置优先级 : 线程优先级 « 线 « Java 教程

En
Java 教程
1. 语言基础
2. 数据类型
3. 操作符
4. 流程控制
5. 类定义
6. 开发相关
7. 反射
8. 正则表达式
9. 集合
10. 线
11. 文件
12. 泛型
13. 本土化
14. Swing
15. Swing事件
16. 二维图形
17. SWT
18. SWT 二维图形
19. 网络
20. 数据库
21. Hibernate
22. JPA
23. JSP
24. JSTL
25. Servlet
26. Web服务SOA
27. EJB3
28. Spring
29. PDF
30. 电子邮件
31. 基于J2ME
32. J2EE应用
33. XML
34. 设计模式
35. 日志
36. 安全
37. Apache工具
38. 蚂蚁编译
39. JUnit单元测试
Java
Java 教程 » 线 » 线程优先级 
10. 3. 4. 如何设置优先级
/*
 * Copyright (c) 2004 David Flanagan.  All rights reserved.
 * This code is from the book Java Examples in a Nutshell, 3nd Edition.
 * It is provided AS-IS, WITHOUT ANY WARRANTY either expressed or implied.
 * You may study, use, and modify it for any non-commercial purpose,
 * including teaching and use in open-source projects.
 * You may distribute it non-commercially as long as you retain this notice.
 * For a commercial use license, or to purchase the book, 
 * please visit http://www.davidflanagan.com/javaexamples3.
 */

/**
 * This class demonstrates the use of threads. The main() method is the initial
 * method invoked by the interpreter. It defines and starts two more threads and
 * the three threads run at the same time. Note that this class extends Thread
 * and overrides its run() method. That method provides the body of one of the
 * threads started by the main() method
 */
public class ThreadDemo extends Thread {
  /**
   * This method overrides the run() method of Thread. It provides the body for
   * this thread.
   */
  public void run() {
    for (int i = 0; i < 5; i++)
      compute();
  }

  /**
   * This main method creates and starts two threads in addition to the initial
   * thread that the interpreter creates to invoke the main() method.
   */
  public static void main(String[] args) {
    // Create the first thread: an instance of this class. Its body is
    // the run() method above
    ThreadDemo thread1 = new ThreadDemo();

    // Create the second thread by passing a Runnable object to the
    // Thread() construtor. The body of this thread is the run() method
    // of the anonymous Runnable object below.
    Thread thread2 = new Thread(new Runnable() {
      public void run() {
        for (int i = 0; i < 5; i++)
          compute();
      }
    });

    // Set the priorities of these two threads, if any are specified
    if (args.length >= 1)
      thread1.setPriority(Integer.parseInt(args[0]));
    if (args.length >= 2)
      thread2.setPriority(Integer.parseInt(args[1]));

    // Start the two threads running
    thread1.start();
    thread2.start();

    // This main() method is run by the initial thread created by the
    // Java interpreter. Now that thread does some stuff, too.
    for (int i = 0; i < 5; i++)
      compute();

    // We could wait for the threads to stop running with these lines
    // But they aren't necessary here, so we don't bother.
    // try {
    // thread1.join();
    // thread2.join();
    // } catch (InterruptedException e) {}

    // The Java VM exits only when the main() method returns, and when all
    // threads stop running (except for daemon threads--see setDaemon()).
  }

  // ThreadLocal objects respresent a value accessed with get() and set().
  // But they maintain a different value for each thread. This object keeps
  // track of how many times each thread has called compute().
  static ThreadLocal numcalls = new ThreadLocal();

  /** This is the dummy method our threads all call */
  static synchronized void compute() {
    // Figure out how many times we've been called by the current thread
    Integer n = (Integernumcalls.get();
    if (n == null)
      n = new Integer(1);
    else
      n = new Integer(n.intValue() 1);
    numcalls.set(n);

    // Display the name of the thread, and the number of times called
    System.out.println(Thread.currentThread().getName() ": " + n);

    // Do a long computation, simulating a "compute-bound" thread
    for (int i = 0, j = 0; i < 1000000; i++)
      j += i;

    // Alternatively, we can simulate a thread subject to network or I/O
    // delays by causing it to sleep for a random amount of time:
    try {
      // Stop running for a random number of milliseconds
      Thread.sleep((int) (Math.random() 100 1));
    catch (InterruptedException e) {
    }

    // Each thread politely offers the other threads a chance to run.
    // This is important so that a compute-bound thread does not "starve"
    // other threads of equal priority.
    Thread.yield();
  }
}
10. 3. 线程优先级
10. 3. 1. 改变线程优先级
10. 3. 2. 线程优先级
10. 3. 3. 最低和最高优先级
10. 3. 4. 如何设置优先级
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.