java线程的阻塞及唤醒

1. sleep() 方法:
sleep(…毫秒),指定以毫秒为单位的时间,使线程在该时间内进入线程阻塞状态,期间得不到cpu的时间片,等到时间过去了,线程重新进入可执行状态。(暂停线程,不会释放锁)
//测试sleep()方法
class Thread7 implements Runnable{
@Override
public void run() {
for(int i=0;i<50;i++){
System.out.println(Thread.currentThread().getName()+"num="+i);
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class Thread8 implements Runnable{
@Override
public void run() {
for(int i=0;i<1000;i++){
System.out.println(Thread.currentThread().getName()+"num="+i);
}
}
}
public static void main(String[] args) {
/*
* 测试线程阻塞
*/
//测试sleep()方法
Thread7 t7=new Thread7();
Thread8 t8=new Thread8();
Thread t81=new Thread(t8, "饺子");
Thread t71=new Thread(t7, "包子");
Thread t72=new Thread(t7, "面包");
t71.start();
t81.start();
t72.start();
}
2.suspend() 和 resume() 方法:。
挂起和唤醒线程,suspend()使线程进入阻塞状态,只有对应的resume()被调用的时候,线程才会进入可执行状态。(不建议用,容易发生死锁)
//测试suspend()和resume()方法
class Thread9 implements Runnable{
@Override
public void run() {
for(long i=0;i<500000000;i++){
System.out.println(Thread.currentThread().getName()+" num= "+i);
}
}
}
public static void main(String[] args) {
//测试suspend和resume
Thread9 t9=new Thread9();
Thread t91=new Thread(t9,"包子");
t91.start();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
t91.suspend();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
t91.resume();
}
(在控制台打印输出的时候,会停顿2秒钟,然后再继续打印。)
3. yield() 方法:
会使的线程放弃当前分得的cpu时间片,但此时线程任然处于可执行状态,随时可以再次分得cpu时间片。yield()方法只能使同优先级的线程有执行的机会。调用 yield() 的效果等价于调度程序认为该线程已执行了足够的时间从而转到另一个线程。(暂停当前正在执行的线程,并执行其他线程,且让出的时间不可知)
//测试yield()方法
class Thread10 implements Runnable{
@Override
public void run() {
for(int i=0;i<100;i++){
System.out.println(Thread.currentThread().getName()+" num= "+i);
if(i==33){
Thread.yield();
}
}
}
}
public static void main(String[] args) {
//测试yield
Thread10 t10 =new Thread10();
Thread t101=new Thread(t10, "包子");
Thread t102=new Thread(t10, "面包");
t101.start();
t102.start();
}
/*
运行结果为:
……
包子 num= 24
包子 num= 25
包子 num= 26
包子 num= 27
包子 num= 28
包子 num= 29
包子 num= 30
包子 num= 31
包子 num= 32
包子 num= 33
面包 num= 0
面包 num= 1
面包 num= 2
面包 num= 3
……
面包 num= 30
面包 num= 31
面包 num= 32
面包 num= 33
包子 num= 34
包子 num= 35
包子 num= 36
包子 num= 37
包子 num= 38
……
*/
(可以看到,当数字为33时,都发生了交替。)
4.wait() 和 notify() 方法:
两个方法搭配使用,wait()使线程进入阻塞状态,调用notify()时,线程进入可执行状态。wait()内可加或不加参数,加参数时是以毫秒为单位,当到了指定时间或调用notify()方法时,进入可执行状态。(属于Object类,而不属于Thread类,wait( )会先释放锁住的对象,然后再执行等待的动作。由于wait( )所等待的对象必须先锁住,因此,它只能用在同步化程序段或者同步化方法内,否则,会抛出异常IllegalMonitorStateException.)
//测试wait()和notify()方法
//用生产者和消费者模式模拟这一过程
/*消费者 */
class Consumer implements Runnable {
private Vector obj;
public Consumer(Vector v) {
this.obj = v;
}
public void run() {
synchronized (obj) {
while (true) {
try {
if (obj.size() == 0) {
obj.wait();
}
System.out.println("消费者:我要买面包。");
System.out.println("面包数: " + obj.size());
obj.clear();
obj.notify();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
/* 生产者 */
class Producter implements Runnable {
private Vector obj;
public Producter(Vector v) {
this.obj = v;
}
public void run() {
synchronized (obj) {
while (true) {
try {
if (obj.size() != 0) {
obj.wait();
}
obj.add(new String("面包"));
obj.notify();
System.out.println("生产者:面包做好了。");
Thread.sleep(500);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}
public static void main(String[] args) {
//测试wait()和notify()
Vector obj = new Vector();
Thread consumer = new Thread(new Consumer(obj));
Thread producter = new Thread(new Producter(obj));
consumer.start();
producter.start();
}
5.join()方法
也叫线程加入。是当前线程A调用另一个线程B的join()方法,当前线程转A入阻塞状态,直到线程B运行结束,线程A才由阻塞状态转为可执行状态。
//测试join
class Thread11 implements Runnable{
@Override
public void run() {
System.out.println("Start Progress.");
try {
for(int i=0;i<5;i++){
System.out.println("Thread11线程 : "+i);
Thread.sleep(1000);
}
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("End Progress.");
}
}
public static void main(String[] args) {
//测试join
Thread11 t11=new Thread11();
Thread t111=new Thread(t11);
t111.start();
try {
t111.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("hi,I'm Main线程");
}
/*
运行结果为:
Start Progress.
Thread11线程 : 0
Thread11线程 : 1
Thread11线程 : 2
Thread11线程 : 3
Thread11线程 : 4
End Progress.
hi,I'm Main线程
*/
总结
本文关于Java多线程阻塞与唤醒代码示例的介绍就到这里,希望对大家学习Java有所帮助。感兴趣的朋友可以继续参阅:Java多线程ForkJoinPool实例详解 、 Java通过卖票理解多线程 、 Java线程安全基础概念解析等。有什么问题可以随时留言,或者有什么方面想要了解的,您也可以留言,小编会及时给您答复。希望大家对多多支持!
# java
# 多线程
# 阻塞
# 唤醒
# java多线程
# 示例
# Java多线程中停止线程遇到线程阻塞的处理方法详解
# Java的线程阻塞、中断及优雅退出方法详解
# Java线程阻塞和唤醒的几种方式详解
# Java线程阻塞的方法区别详解
# java调用process线程阻塞问题的解决
# java实现线程阻塞式方法
# 可执行
# 有什么
# 然后再
# 死锁
# 锁住
# 这一
# 才会
# 感兴趣
# 转到
# 而不
# 时间内
# 给您
# 可以看到
# 希望大家
# 会使
# 能使
# 就到
# 用在
# 不加
相关文章:
如何在腾讯云服务器快速搭建个人网站?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何破解联通资金短缺导致的基站建设难题?
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何选择高性价比服务器搭建个人网站?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
如何用AWS免费套餐快速搭建高效网站?
公司网站制作价格怎么算,公司办个官网需要多少钱?
网页设计网站制作软件,microsoft office哪个可以创建网页?
详解jQuery停止动画——stop()方法的使用
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
内部网站制作流程,如何建立公司内部网站?
建站之星展会模版如何一键下载生成?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
建站之星3.0如何解决常见操作问题?
电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?
建站之星图片链接生成指南:自助建站与智能设计教程
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
长沙做网站要多少钱,长沙国安网络怎么样?
相册网站制作软件,图片上的网址怎么复制?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
,南京靠谱的征婚网站?
如何选择适合PHP云建站的开源框架?
电商网站制作公司有哪些,1688网是什么意思?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
免费ppt制作网站,有没有值得推荐的免费PPT网站?
北京建设网站制作公司,北京古代建筑博物馆预约官网?
制作充值网站的软件,做人力招聘为什么要自己交端口钱?
如何快速启动建站代理加盟业务?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
网站制作员失业,怎样查看自己网站的注册者?
如何通过PHP快速构建高效问答网站功能?
建站主机默认首页配置指南:核心功能与访问路径优化
实例解析Array和String方法
北京企业网站设计制作公司,北京铁路集团官方网站?
如何在服务器上配置二级域名建站?
宝塔面板如何快速创建新站点?
深圳网站制作的公司有哪些,dido官方网站?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
已有域名和空间如何快速搭建网站?
如何选择建站程序?包含哪些必备功能与类型?
如何通过万网虚拟主机快速搭建网站?
微信小程序 五星评分(包括半颗星评分)实例代码
已有域名如何免费搭建网站?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
如何注册花生壳免费域名并搭建个人网站?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
开封网站制作公司,网络用语开封是什么意思?
*请认真填写需求信息,我们会在24小时内与您取得联系。