线程的创建和状态(操作系统和java)

简介: 线程的创建和状态(操作系统和java)

线程的创建和状态(操作系统和java)


线程的创建方式

继承Thread
  class MyThread extends Thread {
    @Override
    public void run() {
    }
  }
  MyThread t = new MyThread();
  t.start()
  实现Runnable接口 推荐
  class MyRunnable implements Runnable {
    @Override
    public void run() {
    }
  }
  MyRunnable my = new MyRunnable();
  Thread t = new Thread(my);
  t.start()
  匿名内部类方式操作
  new Thread(new Runnable() {
    @Override
    public void run() {
    }
  });

线程的状态

操作系统层面 5种状态

新建 就绪 运行 终止 阻塞

Java里面 6种状态

新建状态: new 创建线程对象

可运行状态:start()方法,进入可运行状态,线程可能开始运行,也可能没有运行

刚start() ,线程相当于先进入就绪状态,获取cpu资源,进入运行状态

cpu时间片到期,yield() 线程回到就绪状态

阻塞状态:通过同步方法、同步代码块对象程序加锁,其他线程访问已加锁的代码时,进入阻塞状态

当线程释放锁,阻塞的线程进入可运行状态,哪个线程抢到cpu资源,该线程执行相关程序,并继续加锁

等待状态:线程中调用wait()/join()等方法,线程进入等待状态

其他线程通过notify()唤醒等待的线程,或者join的线程执行完毕,线程线程进入可运行状态

计时等待状态:sleep(long)/wait(long)/join(long) 进入计时等待状态

终止状态:run方法正常执行完毕,或者报异常

线程的调度

sleep() 哪个线程调用sleep方法,哪个线程就休眠
join() 线程插队 ,插队的线程先执行完,其他的线程才会继续执行
yield()线程礼让 哪个线程中调用yield方法,哪个线程进入就绪状态

线程同步

针对线程安全:多个线程访问共享的数据

同步机制

同步方法 synchronized 修饰方法

同步代码块

synchronized(锁对象) {

需要同步执行的代码

}

锁对象必须唯一,相当于多个线程共享一把锁

单例设计模式

整个程序中,如果某个类的对象只需要一个,这个时候就可以使用单例模式

懒汉式

饿汉式 推荐

注意:构造方法需要设置为private
相关实践学习
CentOS 7迁移Anolis OS 7
龙蜥操作系统Anolis OS的体验。Anolis OS 7生态上和依赖管理上保持跟CentOS 7.x兼容,一键式迁移脚本centos2anolis.py。本文为您介绍如何通过AOMS迁移工具实现CentOS 7.x到Anolis OS 7的迁移。
相关文章
|
5天前
|
安全 Java 数据库
一天十道Java面试题----第四天(线程池复用的原理------>spring事务的实现方式原理以及隔离级别)
这篇文章是关于Java面试题的笔记,涵盖了线程池复用原理、Spring框架基础、AOP和IOC概念、Bean生命周期和作用域、单例Bean的线程安全性、Spring中使用的设计模式、以及Spring事务的实现方式和隔离级别等知识点。
|
5天前
|
存储 监控 安全
一天十道Java面试题----第三天(对线程安全的理解------>线程池中阻塞队列的作用)
这篇文章是Java面试第三天的笔记,讨论了线程安全、Thread与Runnable的区别、守护线程、ThreadLocal原理及内存泄漏问题、并发并行串行的概念、并发三大特性、线程池的使用原因和解释、线程池处理流程,以及线程池中阻塞队列的作用和设计考虑。
|
3天前
|
存储 缓存 安全
深度剖析Java HashMap:源码分析、线程安全与最佳实践
深度剖析Java HashMap:源码分析、线程安全与最佳实践
|
6天前
|
安全 Java
Java模拟生产者-消费者问题。生产者不断的往仓库中存放产品,消费者从仓库中消费产品。其中生产者和消费者都可以有若干个。在这里,生产者是一个线程,消费者是一个线程。仓库容量有限,只有库满时生产者不能存
该博客文章通过Java代码示例演示了生产者-消费者问题,其中生产者在仓库未满时生产产品,消费者在仓库有产品时消费产品,通过同步机制确保多线程环境下的线程安全和有效通信。
|
4天前
|
缓存 前端开发 JavaScript
一篇文章助你搞懂java中的线程概念!纯干货,快收藏!
【8月更文挑战第11天】一篇文章助你搞懂java中的线程概念!纯干货,快收藏!
13 0
一篇文章助你搞懂java中的线程概念!纯干货,快收藏!
|
3天前
|
算法 安全 Java
深入解析Java多线程:源码级别的分析与实践
深入解析Java多线程:源码级别的分析与实践
|
4天前
|
Java 程序员 调度
深入浅出Java多线程编程
Java作为一门成熟的编程语言,在多线程编程方面提供了丰富的支持。本文将通过浅显易懂的语言和实例,带领读者了解Java多线程的基本概念、创建方法以及常见同步工具的使用,旨在帮助初学者快速入门并掌握Java多线程编程的基础知识。
4 0
|
5天前
|
Java
java中获取当前执行线程的名称
这篇文章介绍了两种在Java中获取当前执行线程名称的方法:使用`Thread`类的`getName`方法直接获取本线程的名称,以及使用`Thread.currentThread()`方法获取当前执行对象的引用再调用`getName`方法。
|
5天前
|
Java 测试技术
Java SpringBoot Test 单元测试中包括多线程时,没跑完就结束了
Java SpringBoot Test 单元测试中包括多线程时,没跑完就结束了
10 0
|
5天前
|
Java
Java多线程-死锁的出现和解决
死锁是指多线程程序中,两个或以上的线程在运行时因争夺资源而造成的一种僵局。每个线程都在等待其中一个线程释放资源,但由于所有线程都被阻塞,故无法继续执行,导致程序停滞。例如,两个线程各持有一把钥匙(资源),却都需要对方的钥匙才能继续,结果双方都无法前进。这种情况常因不当使用`synchronized`关键字引起,该关键字用于同步线程对特定对象的访问,确保同一时刻只有一个线程可执行特定代码块。要避免死锁,需确保不同时满足互斥、不剥夺、请求保持及循环等待四个条件。

热门文章

最新文章