- 博客(6)
- 收藏
- 关注
原创 Java并发基础:LockSupport.park与LockSupport.unpark的底层原理
1.调用park方法时,若count为1,则count减1,线程不会被阻塞,继续运行;若count为0,则线程阻塞,并加入到mutex的condition队列中等待。2.调用unpark方法时,若程序正在运行,则count设置为1,程序继续运行;若程序在condition队列中阻塞等待,则唤醒线程继续运行。:每个线程都有一个park对象,其主要属性有mutex、condition和count,count取值为0或1。
2024-07-05 17:26:46 191
原创 Java并发基础:Thread类常用方法
是Thread类中的静态方法,当一个执行中的线程调用了Thread的sleep()方法后,调用线程会暂时让出时间的执行权,转为Timed_Waiting状态,这期间不参与cpu的调度,但是。:可运行线程的线程状态。如果在睡眠期间,其他线程调用了该线程的interrupt()的方法中断了该线程,则该线程会抛出InterruptedException异常而返回。:使当前线程由执行状态,变成为就绪状态,主动让出CPU,在下一个线程执行时候,此线程有可能被执行,也有可能没有被执行,由任务调度器最终决定。
2024-07-05 14:50:15 135
原创 Java并发基础:CyclicBarrier
每有一个线程到达,count减1,当count减为0时,唤醒所有线程,并重置broken、count。barrierCommand:Runnable接口的实例,在CyclicBarrier初始化时可以设置,其为一个任务,会在每次唤醒所有线程前执行。状态量parties:表示每次需要累计的线程数量,CyclicBarrier初始化时设置,每次打破栅栏后,重置count为parties的值。队列trip:为Condition的实例,记录等待的线程,当count减为0时,将队列中的线程全部唤醒。
2024-07-03 21:13:00 584
原创 Java并发基础:CountDownLatch
3.countDown():调用AQS的releaseShared()方法,会先调用tryReleaseShared()方法,将state减1,若减完后,state等于0,则返回true,否则返回false。若返回true,则表示CountDownLatch倒计时结束,将AQS等待队列中的所有线程全部唤醒。2.await(): 底层调用AQS的acquireSharedInterruptibly(1)方法,将线程加入到AQS的等待队列的队尾,如果state已减为0,则什么都不做。
2024-07-03 20:23:01 139
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人