JUC简介:进程和线程、线程的状态、wait与sleep的区别、串行与并行、并行与并发、管程、用户线程与守护线程

JUC简介:进程和线程、线程的状态、wait与sleep的区别、串行与并行、并行与并发、管程、用户线程与守护线程,第1张

文章目录
  • 1. 简介
  • 2. 进程和线程
  • 3. 线程的状态
  • 4. wait与sleep的区别
  • 5. 串行与并行
    • 5.1 串行模式
    • 5.2 并行模式
  • 6. 并行与并发
  • 7. 管程的概念
  • 8. 用户线程与守护线程

1. 简介

在Java中,线程部分是一个重点,本篇文章说的JUC也是关于线程的。JUC就是java.util.concurrent工具包的简称。这是一个处理线程的工具包,JDK1.5开始出现的。

2. 进程和线程

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是 *** 作系统结构的基础。在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是 *** 作系统结构的基础。程序是指令、数据及其组织形式的描述,进程是程序的实体。

线程(thread)是 *** 作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。

3. 线程的状态
  • new:新建
  • runnable:准备就绪
  • blocked:阻塞
  • waiting:等待
  • timed_waiting:等待超时就不等了
  • terminated:终结
4. wait与sleep的区别
  1. sleep是Thread的静态方法,wait是Object的方法,任何对象实例都能调用。
  2. sleep不会释放锁,它也不需要占用锁。wait会释放锁,但调用它的前提是当前线程占有锁(即代码要在synchronized中)。
  3. 它们都可以被interrupted方法中断。
5. 串行与并行 5.1 串行模式

串行表示所有任务都一一按先后顺序进行。串行意味着必须先装完一车柴才能运送这车柴,只有运送到了,才能卸下这车柴,并且只有完成了这整个三个步骤,才能进行下一个步骤。
串行是一次只能取得一个任务,并执行这个任务

5.2 并行模式

并行意味着可以同时取得多个任务,并同时去执行所取得的这些任务。并行模式相当于将长长的一条队列,划分成了多条短队列,所以并行缩短了任务队列。

6. 并行与并发

并发:同一时刻多个线程在访问同一个资源,多个线程对一个点。
例子:春运抢票电商秒杀…

并行:多项工作一起执行,之后再汇总
例子:泡方便面,电水壶烧水,一边撕调料倒入桶中

7. 管程的概念
  • 英文叫Monitor,翻译过来是监视器,就是我们平时说的锁。
  • 本身是一种同步机制,保证同一个时间,只有一个线程访问被保护数据或者代码。
  • jvm同步基于进入和退出,使用管程对象实现
8. 用户线程与守护线程
  • 用户线程:用户自定义的线程
  • 守护线程:比如垃圾回收

main线程结束了,但是用户线程依旧会继续运行,jvm继续运行。

public class 用户自定义线程 {
    public static void main(String[] args) {
        Thread aa = new Thread(() -> {
            //isDaemon():判断是否为守护线程
            System.out.println(Thread.currentThread().getName() + "::" + Thread.currentThread().isDaemon());
            while (true) {

            }
        }, "aa");
        aa.start();

        System.out.println(Thread.currentThread().getName() + "over");
    }
}

main线程结束了,守护线程也跟着结束了,jvm结束 。

public class 用户自定义线程 {
    public static void main(String[] args) {
        Thread aa = new Thread(() -> {
            //isDaemon():判断是否为守护线程
            System.out.println(Thread.currentThread().getName() + "::" + Thread.currentThread().isDaemon());
            while (true) {

            }
        }, "aa");
        //变为守护线程
        aa.setDaemon(true);
        aa.start();

        System.out.println(Thread.currentThread().getName() + "over");
    }
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/729439.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-27
下一篇 2022-04-27

发表评论

登录后才能评论

评论列表(0条)

保存