线程的创建和使用(3)线程的常用方法
一、构造器
- Thread():创建新的Thread对象
- Thread(String threadname):创建线程并指定线程实例名
- Thread(Runnable target):指定创建线程的目标对象,它实现了Runnable接口中的run方法
- Thread(Runnable target, String name):创建新的Thread对象
二、Thread类的有关方法
- start():启动当前线程;调用当前线程的run()
- run(): 通常需要重写Thread类中的此方法,将创建的线程要执行的操作声明在此方法中
- String getName(): 返回线程的名称
- void setName(String name):设置该线程名称
- static Thread currentThread(): 返回当前线程。在Thread子类中就是this,通常用于主线程和Runnable实现类;currentThread():静态方法,返回执行当前代码的线程
- static void yield():线程让步,释放当前cpu的执行权
(1)暂停当前正在执行的线程,把执行机会让给优先级相同或更高的线程
(2)若队列中没有同优先级的线程,忽略此方法 - join() :当某个程序执行流中调用其他线程的 join() 方法时,调用线程将被阻塞,直到 join() 方法加入的 join 线程执行完为止;在线程a中调用线程b的join(),此时线程a就进入阻塞状态,直到线程b完全执行完以后,线程a才结束阻塞状态。
(1)低优先级的线程也可以获得执行 - static void sleep(long millis):(指定时间:毫秒) 让当前线程“睡眠”指定的millitime毫秒。在指定的millitime毫秒时间内,当前线程是阻塞状态。
(1)令当前活动线程在指定时间段内放弃对CPU控制,使其他线程有机会被执行,时间到后重排队。
(2)抛出InterruptedException异常 - stop(): 已过时。当执行此方法时,强制结束当前线程。不推荐使用
- boolean isAlive():返回boolean,判断线程是否存活
三、优先级
线程的优先级:
1.
MAX_PRIORITY:10
MIN _PRIORITY:1
NORM_PRIORITY:5 -->默认优先级
2.如何获取和设置当前线程的优先级:
getPriority():获取线程的优先级
setPriority(int p):设置线程的优先级
说明:高优先级的线程要抢占低优先级线程cpu的执行权。但是只是从概率上讲,高优先级的线程高概率的情况下被执行。并不意味着只有当高优先级的线程执行完以后,低优先级的线程才执行。
代码:
package java1;
class HelloThread extends Thread{
@Override
public void run() {
for (int i = 0; i < 100; i++) {
if(i % 2 == 0){
// try {
// sleep(1000);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
System.out.println(Thread.currentThread().getName() + ":" + Thread.currentThread().getPriority() + ":" + i);
}
// if(i % 20 == 0){
// yield();
// }
}
}
public HelloThread(String name){
super(name);
}
}
public class ThreadMethodTest {
public static void main(String[] args) {
HelloThread h1 = new HelloThread("Thread:1");
// h1.setName("线程一");
//设置分线程的优先级
h1.setPriority(Thread.MAX_PRIORITY);
h1.start();
//给主线程命名
Thread.currentThread().setName("主线程");
Thread.currentThread().setPriority(Thread.MIN_PRIORITY);
for (int i = 0; i < 100; i++) {
if(i % 2 == 0){
System.out.println(Thread.currentThread().getName() + ":" + Thread.currentThread().getPriority() + ":" + i);
}
// if(i == 20){
// try {
// h1.join();
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// }
}
// System.out.println(h1.isAlive());
}
}
输出:
主线程:1:0
主线程:1:2
主线程:1:4
主线程:1:6
主线程:1:8
Thread:1:10:0
主线程:1:10
主线程:1:12
主线程:1:14
主线程:1:16
主线程:1:18
主线程:1:20
主线程:1:22
主线程:1:24
主线程:1:26
主线程:1:28
Thread:1:10:2
Thread:1:10:4
Thread:1:10:6
Thread:1:10:8
Thread:1:10:10
Thread:1:10:12
Thread:1:10:14
Thread:1:10:16
Thread:1:10:18
主线程:1:30
Thread:1:10:20
Thread:1:10:22
Thread:1:10:24
Thread:1:10:26
Thread:1:10:28
Thread:1:10:30
Thread:1:10:32
Thread:1:10:34
Thread:1:10:36
主线程:1:32
主线程:1:34
主线程:1:36
主线程:1:38
主线程:1:40
主线程:1:42
主线程:1:44
主线程:1:46
主线程:1:48
主线程:1:50
主线程:1:52
主线程:1:54
主线程:1:56
主线程:1:58
Thread:1:10:38
Thread:1:10:40
主线程:1:60
主线程:1:62
主线程:1:64
主线程:1:66
主线程:1:68
Thread:1:10:42
主线程:1:70
Thread:1:10:44
主线程:1:72
Thread:1:10:46
Thread:1:10:48
Thread:1:10:50
Thread:1:10:52
主线程:1:74
Thread:1:10:54
主线程:1:76
主线程:1:78
主线程:1:80
主线程:1:82
Thread:1:10:56
Thread:1:10:58
Thread:1:10:60
Thread:1:10:62
Thread:1:10:64
Thread:1:10:66
Thread:1:10:68
Thread:1:10:70
Thread:1:10:72
Thread:1:10:74
主线程:1:84
主线程:1:86
主线程:1:88
主线程:1:90
主线程:1:92
主线程:1:94
Thread:1:10:76
Thread:1:10:78
主线程:1:96
主线程:1:98
Thread:1:10:80
Thread:1:10:82
Thread:1:10:84
Thread:1:10:86
Thread:1:10:88
Thread:1:10:90
Thread:1:10:92
Thread:1:10:94
Thread:1:10:96
Thread:1:10:98