Thread

作者: 填坑之路_DK | 来源:发表于2021-04-01 11:26 被阅读0次

Thread 创建方式

  • 继承Thread
  • 实现 Runnable 接口
  • lanbda 表达式 new Thread(()->}{...}).start; 实际上第二种相同
  • 线程池创建

常用方法

sleep
  • 睡眠线程
  • 不可被主动唤醒 (回到就绪状态)
  • 不释放锁
  • 仅能操作当前线程
wait
  • 休眠线程
  • 可被 notify notifyAll 唤醒,唤醒后续重新拿锁 (回到就绪状态)
  • 释放锁
  • 能操作指定线程对象
  • wait只能在同步(synchronize)环境中被调用,非同步直接报错(无法获取到锁)
notify notifyAll
  • 唤醒 被wait的线程
yield
  • 使线程返回到就绪状态
  • 一定会退出cpu一次
  • 不保证当前的线程会暂停
  • 退出cpu会从队列中根据优先级重新执行某线程
join
  • 加入其他线程中执行
  • 指定当前线程是无效
  • 从执行出(t2.join())阻塞,直到t2线程结束

interrupt

  • 对于正常线程来说,只是改变中断状态,即Thread.isInterrupted()返回true
  • 对于阻塞线程来说(wait,join,sleep),将抛出InterruptedException
getState
  • 获取线程状态

Thread 状态

  • New : 刚new 出来 未被start
  • Ready: 就绪状态
  • Running: 被cpu执行
  • TimedWaiting: 指定时间等待
  • Waiting: 等待
  • Blocked: 阻塞 拿锁
  • Teminated: 终止

常用工具类

CountDownLatch
  • 判断N个线程是否全部执行完
  • 阻塞
// 十个线程(计数器为10)
CountDownLatch latch=new CountDownLatch(10);
//计数器-1
latch.countDown(); 
//阻塞 当计数器为0是继续执行
latch.await(); 
CyclicBarrier
  • 攒够一定线程后批量执行
  • 阻塞
//攒多少个线程,攒够后执行的方法
CyclicBarrier barriar = new CyclicBarrier(10,new Runnable(){  
    @Override
    public void run(){
        System.out.println("攒够了");
    }
})
 //阻塞 攒够指定线程数量后批量执
barriar.await();
Phaser
  • 攒够线程后执行 分段
  • 阻塞
Phaser phaser = new  Phaser();
//注册线程数量
phaser.bulkRegister(7); 
//到达栅栏,等待继续往前走
phaser.arriveAndAwaitAdvance();
// 到达栅栏,不注册,后续步骤与该线程无关
phaser.arriveAndDeregister();
@Override
//满足栅栏条件后自动执行  当前在第几步  此阶段
public boolean onAdvance(int phase,int registeredParties){参加线程
    switch(phase){
        case 0:
            //继续执行
            return false; 
        default:
            //不继续执行
            return true; 
    } 
}
Semaphore
  • 可用于限流
  • 可公平
  • 队列
//允许同时进行多少个线程 是否公平
Semaphore s = new Semaphore(1,true);
// 允许数-1 ,当前为0 则进入队列
s.acquire();
//允许数+1
s.releas();
Exchanger
  • 线程通信
  • 用于两个线程交换数据
  • 阻塞
Exchanger<T> ex=new Exchanger<>();
//阻塞,内部有两个位置 将两个线程的值交换返回(有两个值时继续执行)
t=ex.exchange(t); 
LockSupport
  • 阻塞当前线程
  • 解锁指定线程
  • wait()必须借助锁 而 LockSupport 不需要
LockSupport.park();
LockSupport.unPark(t);

相关文章

网友评论

      本文标题:Thread

      本文链接:https://www.haomeiwen.com/subject/qwmbhltx.html