Java中的线程状态之堵塞

本文通过实例演示了Java中线程的控制方法,包括join、yield及sleep的使用技巧。重点解析了sleep方法如何影响多线程之间的资源竞争,展示了在特定场景下可能出现的资源抢夺现象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package cpm.thread.creater;

public class joinDemo1 extends Thread {

    public static void main(String[] args) throws InterruptedException {
        
        joinDemo1 ab   =new joinDemo1();
        Thread t=new Thread(ab);
        t.start();
        for(int i=0;i<=100;i++)
        {
            if(i==50)
                t.join();
            System.out.println(i);
        }
    }
@Override
public void run() {
    
    for(int i=0;i<=100;i++)
    {
        System.out.println(i);
    }
}
}

当      t.join(); 这个代表必须等t终止后。main方法的线程才会继续执行,    t.yield();代表暂停该线程

下面我们重点讲sleep()方法

package cpm.thread.creater;

public class Sleep {

    public static void main(String[] args) {
        
        Web12306 ab= new Web12306();
        Thread proxy=new Thread(ab,"甲");
        Thread proxy2=new Thread(ab,"乙");
        Thread proxy3=new Thread(ab,"丙");
        proxy.start();
        proxy2.start();
        proxy3.start();
    }

}

class Web12306 implements Runnable
{
    private int num =50;
    @Override
    public void run() {
        while(true)
        {
            if(num<=0)
            {
                break;
            }
            try {
                Thread.sleep(500);
            } catch (InterruptedException e) {
                
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+num--);
        }
        
    }
    }


为什么要重点讲,并不是sleep方法有多难,运行这个程序,我们会发现最后运行到了 -1.

这是为什么了,实际上我们运行了3个线程,当最后一步时,甲拿走1,乙拿走0,丙拿走-1,这就是多线程对于资源的抢夺,也是并发产生的原因

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值