线程停止\休眠sleep\礼让yield\插队 join

通过标识位停止

  • 1建议线程正常停止--->利用次数,不建议死循环。
  • 2建议使用标志位--->设置一个标志位
  • 3不要使用stop或者destroy等过时或者JDK不建议使用的方法
package Thread.Demo06;

/**
 * 测试stop
 * 1建议线程正常停止--->利用次数,不建议死循环。
 * 2建议使用标志位--->设置一个标志位
 * 3不要使用stop或者destroy等过时或者JDK不建议使用的方法
 *
 * @author liu
 */
public class Stop implements Runnable {
    //1设置标识位
    private boolean flag = true;

    @Override
    public void run() {
        int i = 0;
        while (flag) {
            System.out.println("run--thread " + i++ + "次");
        }
    }

    //2设置一个公开的方法停止线程,转换标志位
    public void stop() {
        this.flag = false;
    }


    public static void main(String[] args) {
        Stop stop = new Stop();
        new Thread(stop).start();

        for (int i = 0; i < 2000; i++) {
            System.out.println("main" + i);
            if (i == 1800) {
                stop.stop();
                System.out.println("线程该停止了");

            }
        }
    }
}

线程休眠

sleep(时间)指定当前线程阻塞的毫秒数;
sleep存在异常InterruptedException;
sleep时间达到后线程进入就绪状态;
sleep可以模拟网络延时,倒计时等。
每个对象都有一把锁,sleep不会释放锁
每一个对象都有一个锁,sleep不会释放锁;

作用:放大问题的发生性

package Thread.Demo06;

import com.sun.org.apache.xerces.internal.util.SynchronizedSymbolTable;

import java.text.SimpleDateFormat;
import java.util.Date;

public class Sleep {
    public static void main(String[] args) {
        try {
            tenDown();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }


        //打印当前时间
        //获取当前系统时间
        Date sysTime = new Date(System.currentTimeMillis());
        while (true) {
            try {
                Thread.sleep(1000);
                System.out.println(new SimpleDateFormat("HH:mm:ss").format(sysTime));
                //更新当前时间
                sysTime = new Date(System.currentTimeMillis());
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    //模拟倒计时
    public static void tenDown() throws InterruptedException {
        int num = 10;
        while (true) {
            Thread.sleep(1000);
            System.out.println(num--);
            if (num <= 0) {
                break;
            }
        }
    }
}

线程礼让 yield

礼让线程,让当前正在执行的线程暂停,但不阻塞
将线程从运行状态转为就绪状态
让cpu重新调度,礼让不一定成功!看CPU心情

package Thread.Demo07;

public class Yield {
    public static void main(String[] args) {
        myYield myYield = new  myYield();
        new Thread(myYield,"A").start();
        new Thread(myYield,"B").start();
    }
    

}
class myYield implements Runnable{

    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"线程开始");
        Thread.yield();
        System.out.println(Thread.currentThread().getName()+"线程停止执行");

    }
}

join 插入

join 插队
强制执行完该线程,再执行其他线程

package Thread.Demo08;

/**
 * join 插队
 *强制执行完
 * @author liu
 */
public class Join implements Runnable {
    @Override
    public void run() {
        for (int i = 0; i < 1000; i++) {
            System.out.println("炒鸡VIP来了" + i);
        }
    }


    public static void main(String[] args) throws InterruptedException {
        //启动线程
        Join join = new Join();
        Thread thread = new Thread(join);
        thread.start();

        for (int i = 0; i <300; i++) {
            if (i == 200) {
            thread.join();
            }
            System.out.println("main "+i);
        }
    }
}
posted @   小幼虫虫  阅读(37)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示