首页 > 编程语言 >java并发线程

java并发线程

时间:2023-10-22 21:24:46浏览次数:31  
标签:java Thread 并发 死锁 线程 进程 CPU 守护

在 java 中守护线程和本地线程区别? java 中的线程分为两种:守护线程(Daemon)和用户线程(User)。任何线程都可以设置 为守护线程和用户线程,通过方法 Thread.setDaemon(boolon);true 则把该线程设置为守护线程,反之则为用户线程。 Thread.setDaemon()必须在 Thread.start()之前调用,否则运行时会抛出异常。 两者的区别: 唯一的区别是判断虚拟机(JVM)何时离开,Daemon 是为其他线程提供服务,如果全部的 User Thread 已经撤离,Daemon 没有可服务的线程,JVM 撤离。也可以理解为守护线程是 JVM 自动创建的线程(但不一定),用户线程是程序创建的线程;比如 JVM 的垃圾回收线程 是一个守护线程,当所有线程已经撤离, 不再产生垃圾,守护线程自然就没事可干了,当垃 圾回收线程是 Java 虚拟机上仅剩的线程时,Java 虚拟机会自动离开。 扩展:Thread Dump 打印出来的线程信息,含有 daemon 字样的线程即为守护进程,可能 会有:服务守护进程、编译守护进程、windows 下的监听 Ctrl+break 的守护进程、 Finalizer 守护进程、引用处理守护进程、GC 守护进程。   线程与进程的区别? 进程是操作系统分配资源的最小单元,线程是操作系统调度的最小单元。一个程序至少有一个 进程,一个进程至少有一个线程。   什么是多线程中的上下文切换? 多线程会共同使用一组计算机上的 CPU,而线程数大于给程序分配的 CPU 数量时,为了让各 个线程都有执行的机会,就需要轮转使用 CPU。不同的线程切换使用 CPU 发生的切换数据等 就是上下文切换。   死锁与活锁的区别,死锁与饥饿的区别? 死锁:是指两个或两个以上的进程(或线程)在执行过程中,因争夺资源而造成的一种互相等 待的现象,若无外力作用,它们都将无法推进下去。 产生死锁的必要条件: ⚫ 互斥条件:所谓互斥就是进程在某一时间内独占资源。 ⚫ 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。 ⚫ 不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺。 ⚫ 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。 活锁:任务或者执行者没有被阻塞,由于某些条件没有满足,导致一直重复尝试,失败,尝 试,失败。 活锁和死锁的区别在于,处于活锁的实体是在不断的改变状态,所谓的 “活”, 而处于死锁的实体表现为等待;活锁有可能自行解开,死锁则不能。饥饿:一个或 者多个线程因为种种原因无法获得所需要的资源,导致一直无法执行的状态。 Java 中导致饥饿的原因: ⚫ 高优先级线程吞噬所有的低优先级线程的 CPU 时间。 ⚫ 线程被永久堵塞在一个等待进入同步块的状态,因为其他线程总是能在它之前持续地对该 同步块进行访问。 ⚫ 线程在等待一个本身也处于永久等待完成的对象(比如调用这个对象的 wait 方法),因为其 他线程总是被持续地获得唤醒。 ⚫ Java 中用到的线程调度算法是什么? ⚫ 采用时间片轮转的方式。可以设置线程的优先级,会映射到下层的系统上面的优先级上, 如非特别需要,尽量不要用,防止线程饥饿。

标签:java,Thread,并发,死锁,线程,进程,CPU,守护
From: https://www.cnblogs.com/1011-zslnb/p/17781140.html

相关文章

  • java复习
    1、Java常用集合及特点?List:ArrayList、LinkedList、Vector、StackSet:LinkedSet、HashSet、TreeSetQueue->Deque->LinkedList。Map:HashMap、LinkedHashMap、TreeMapDictionary->HashTable->Properties。Vector:底层数据结构是数组,查询快,增删慢,线程安全,效率低,默认长度为10,超......
  • 什么是java集合框架
    Java集合框架是Java编程语言提供的一组类和接口,用于处理和存储数据集合。它提供了各种数据结构和算法,以便开发者能够高效地操作数据,无需自行实现这些数据结构。Java集合框架的主要目标是提供一种通用的、标准的方法来处理和存储不同类型的数据,使开发更加方便和高效。以下是Java集......
  • Java并发
    Java并发基础并发:多个任务在同一时间段内交替执行并行:多个任务在同一时刻同时执行Java线程创建方式继承Thread和实现接口继承Thread类并重写run,之后调用start方法启动线程,注意:调用run只是普通的方法调用,不会新开线程。例如如下匿名类继承Thread。Threadthread=new......
  • JAVA项目中的常用的异常处理情况
    在Java项目开发中,异常处理是非常重要的一部分。异常是指在程序运行过程中出现的错误或异常情况,如空指针异常、数组越界异常等。合理处理异常可以提高程序的健壮性和可靠性,保证程序的正常运行。首先在Java中,异常处理的基本原则是“捕获异常、处理异常、抛出异常”。在程序......
  • java异常总结
    JAVA项目中的异常处理在Java项目中,异常处理是非常重要的一部分,它可以帮助我们更好地管理和控制程序的运行流程,提高代码的可读性和可维护性。本文将介绍Java项目中常见的异常处理情况,包括异常的分类、处理方式以及最佳实践。一、Java异常的分类Java异常主要分为两大类:受检查异常......
  • java中使用Graphics绘制图形验证图片,为什么图中的文字没有呈现?
       项目中做了一个图形验证的功能。可选择图形中的文字,想出现的效果如上。图形上有文字。而在实际做的过程中,发到测试环境linux系统上去之后,是下面的情况: 只有图,没有文字!于是问了问度娘,说是字体的原因。项目中使用了linux中没有的字体会导致上图的问题。但我是使用了......
  • 进程和线程的认识
     首先,在我们了解多线程之前,我们需要了解进程的概念以及进程和线程是什么关系?为什么我们Java中更多是需要利用多线程去解决一些问题,而不是多进程来解决?今天就让我们来解释一下。它们之间的关系。 什么是进程?进程是操作系统对于正在运行的应用的一种抽象,也就是说,进程可以看作是程......
  • JAVA
    1.Java中的泛型是什么?使用泛型的好处是什么?这是在各种Java泛型面试中,一开场你就会被问到的问题中的一个,主要集中在初级和中级面试中。那些拥有Java1.4或更早版本的开发背景的人都知道,在集合中存储对象并在使用前进行类型转换是多么的不方便。泛型防止了那种情况的发生。它......
  • Java基础 字节输出流 写出数据的三种方式
    void write(int b)  →  一次写一个字节数据 void write(byte[] b)  →  一次写一个字节数组数据 void write(byte[] b, int off, int len)  →  一次写一个字节数组的部分数据参数一:装着所有数据的数组。参数二:起始索引。参数......
  • Java基础 字节输出流写出数据的细节
    1.创建字节输出流对象:FileOutputStreamfos=newFileOutputStream("E:\\Java基础资料\\a.txt");细节①:参数可以是字符串表示的路径,也可以是File对象细节②:如果文件不存在,会创建一个新的空文件,但是要保证父级路径是存在的细节③:如果文件已经存在,则会清空文件 2.写数据:f......