首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >多线程笔记(四)线程的状态,线程的停止,线程的休眠,线程礼让,join,线程优先级,守护线程

多线程笔记(四)线程的状态,线程的停止,线程的休眠,线程礼让,join,线程优先级,守护线程

作者头像
一写代码就开心
发布2021-08-24 10:31:27
发布2021-08-24 10:31:27
71000
代码可运行
举报
文章被收录于专栏:java和pythonjava和python
运行总次数:0
代码可运行

线程

线程方法

线程的停止(建议)

线程的休眠

线程礼让

A和B 两个线程,当CPU执行B的时候,B进行礼让,那么就离开cpu,这个时候B就变为就绪状态,CPU就重新 在A线程和B线程之间进行选择,有可能还是让B线程执行,这个时候就没有礼让成功。

join

相当于插队

线程的优先级

利用代码设置线程的优先级 和 获取线程的优先级

代码语言:javascript
代码运行次数:0
运行
复制
public class Priority {

    public static void main(String[] args) {

        System.out.println(Thread.currentThread().getName()+"===="+Thread.currentThread().getPriority());
        mytest mytest = new mytest();

        Thread thread = new Thread(mytest);
        Thread thread1 = new Thread(mytest);
        Thread thread2 = new Thread(mytest);
        Thread thread3 = new Thread(mytest);
        Thread thread4 = new Thread(mytest);
        Thread thread5 = new Thread(mytest);


        thread.start();
        设置线程的优先级
        thread1.setPriority(2);
        thread1.start();
        thread2.setPriority(8);
        thread2.start();
        thread3.setPriority(9);
        thread3.start();
        thread4.setPriority(5);
        thread4.start();
        thread5.setPriority(1);
        thread5.start();



    }
}

class mytest  implements Runnable{


    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"===="+Thread.currentThread().getPriority());
    }
}

守护线程

main函数就是用户线程 gc 垃圾回收机制 就是 守护线程

当我们执行一段程序,里面有很多的线程,其中一个线程是守护线程,那么当其他线程执行完毕,这个守护线程就关闭了,虚拟机是不管守护线程是否关闭的

代码语言:javascript
代码运行次数:0
运行
复制
public class TestDeamon {
    public static void main(String[] args) {
        god god = new god();
        yhxc yhxc = new yhxc();

        Thread thread = new Thread(god);
        thread.setDaemon(true);
        Thread thread1 = new Thread(yhxc);
        thread.start();
        thread1.start();
    }
}


class god implements Runnable{
    @Override
    public void run() {
        while (true){
            System.out.println("我是守护线程");
        }
    }
}

class yhxc implements Runnable{
    @Override
    public void run() {
       for(int i=0;i<100;i++){
            System.out.println("我是用户线程");
        }
        System.out.println("我结束了");
    }
}

思路:

我们参加一个 用户线程,一个守护线程,如果一个线程要变为守护线程,那么必须手动设置为true。当我们用户线程走完,整个就结束了,虚拟机是不管守护线程是否走完的。

守护线程不用管

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/08/21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 线程
  • 线程方法
  • 线程的停止(建议)
  • 线程的休眠
  • 线程礼让
  • join
  • 线程的优先级
  • 守护线程
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档