必须使用在synchronized(obj)代码块之内,即将当前线程阻塞在同步对象锁obj上。
当前线程释放锁以及CPU执行权,进入等待状态;直至等待时间结束或者被notify()唤醒之后,才进入可运行状态;之后待再次获取cpu执行权以及锁时,执行wait()后的代码。
必须使用在synchronized(obj)代码块之内,用于唤醒同步锁上处于等待状态的线程,使其进入runnable状态。
Notify()为随机唤醒一个处于等待状态的线程;notifyAll()则唤醒全部处于等待状态的线程。
在生产者消费者模型中,通常先唤醒等待的线程,然后使当前的线程等待。
Sleep() | Thread的静态方法 | 任何地方可用 | 释放cpu不释放锁 | 休眠结束后进入Runnable |
Wait() | Object的方法 | 需在同步块中使用 | 释放锁以及cpu | 需notify后进入Runnable |
让出的时间片只会分配给当前线程相同优先级的线程。
-
- Thead的非静态方法
- getId():返回该线程的标识符
- getName()-setName(name):线程的名称
- setPriority(i)-getPriority():优先级
- Thead的非静态方法
从1到10的范围。10表示最高优先级,1表示最低优先级,5是默认值。
与在线程池中等待运行机会的线程相比,当前正在运行的线程可能总是拥有更高的优先级。
-
-
- getState():返回该线程的状态
- setDaemon(true)-isDaemon():设置为守护线程。
-
设置线程为守护线程;且必须在t.start()逻辑之前执行。当主线程存在时一直存在;当主线程消亡时消亡。 守护线程在退出的时候并不会执行finnaly块中的代码,所以将释放资源等操作不要放在finnaly块中执行,这种操作是不安全的
-
-
- isAlive():测试线程是否处于活动状态。
- join()
-
如果一个线程实例A执行了threadB.join(),其含义是:当前线程A会等待threadB线程终止后threadA才会继续执行。一个基友先走在前面突然看见另一个基友落在后面了,这个时候他就会在原处等一等这个基友,等基友赶上来后,就两人携手并进。
-
-
- interrupt(),isInterrupted(),interrupted()
-
T.interrupt():设置当前线程为可中断线程。可中断t.lockInterruptibly()方式加锁并且处于等待获取锁状态的线程。但对于运行中的线程不可中断。
T.isInterrupted():获取的标志位,如果已设置为可中断线程,则为true;获取后再次获取仍为true。
T.interrupted():获取的标志位,如果已设置为可中断线程,则为true;获取后会清除中断状态。
当需中断的逻辑是一个while(true)循环,则使用if(T.isInterrupted()){break;}进行中断;
当需中断的逻辑是一个方法体,则使用if(T.isInterrupted()){return;}进行中断;
还可通过抛出异常的方式中断,if(T.isInterrupted()){throw new InterruptedException();}
如果当前线程t在sleep中,外部调用t.interrupt()。则程序会抛出异常终止:
java.lang.InterruptedException: sleep interrupted