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实现线程阻塞式方法
# 可执行
# 有什么
# 然后再
# 死锁
# 锁住
# 这一
# 才会
# 感兴趣
# 转到
# 而不
# 时间内
# 给您
# 可以看到
# 希望大家
# 会使
# 能使
# 就到
# 用在
# 不加
相关文章:
如何设置并定期更换建站之星安全管理员密码?
c# 在高并发场景下,委托和接口调用的性能对比
建站之星代理商如何保障技术支持与售后服务?
建站10G流量真的够用吗?如何应对访问高峰?
高端云建站费用究竟需要多少预算?
如何破解联通资金短缺导致的基站建设难题?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何生成腾讯云建站专用兑换码?
兔展官网 在线制作,怎样制作微信请帖?
,怎么用自己头像做动态表情包?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
如何将凡科建站内容保存为本地文件?
制作网站的基本流程,设计网站的软件是什么?
微信小程序 五星评分(包括半颗星评分)实例代码
如何快速搭建虚拟主机网站?新手必看指南
如何在云虚拟主机上快速搭建个人网站?
浅析上传头像示例及其注意事项
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
如何在IIS中新建站点并解决端口绑定冲突?
如何在阿里云部署织梦网站?
如何在Windows 2008云服务器安全搭建网站?
宝塔建站助手安装配置与建站模板使用全流程解析
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
微信小程序制作网站有哪些,微信小程序需要做网站吗?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
如何在阿里云域名上完成建站全流程?
存储型VPS适合搭建中小型网站吗?
如何通过VPS建站实现广告与增值服务盈利?
如何快速搭建高效香港服务器网站?
公司门户网站制作流程,华为官网怎么做?
建站之星如何配置系统实现高效建站?
Python lxml的etree和ElementTree有什么区别
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
三星网站视频制作教程下载,三星w23网页如何全屏?
建站之星后台密码遗忘?如何快速找回?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
c++ stringstream用法详解_c++字符串与数字转换利器
C++用Dijkstra(迪杰斯特拉)算法求最短路径
建站之星免费模板:自助建站系统与智能响应式一键生成
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
如何选择适配移动端的WAP自助建站平台?
建站上传速度慢?如何优化加速网站加载效率?
如何自定义建站之星网站的导航菜单样式?
如何在服务器上三步完成建站并提升流量?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
深圳网站制作平台,深圳市做网站好的公司有哪些?
如何在宝塔面板中修改默认建站目录?
如何在IIS中新建站点并配置端口与物理路径?
*请认真填写需求信息,我们会在24小时内与您取得联系。