每日三道面试题之 Java并发编程 (三)

1.什么是上下文切换?

在Java线程知识中,上下文切换是指操作系统在多任务环境下,为了实现多任务的并行执行,需要在运行一个任务(如一个线程或进程)时切换到另一个任务运行的过程。上下文切换是多任务操作系统的核心特性之一,它使得系统可以更有效地利用CPU资源,实现任务的并发执行。

上下文切换具体涉及以下步骤:

  1. 保存当前任务的状态:当操作系统决定执行上下文切换时,首先需要保存当前正在运行的任务的状态,这包括CPU寄存器中的值、程序计数器(PC)的当前位置等。这些信息通常被保存在内存中,以便之后能够恢复该任务的执行。

  2. 恢复下一个任务的状态:操作系统接着会选择另一个任务来执行,并加载这个任务之前保存的状态信息,包括恢复CPU寄存器的值、设置程序计数器等,使得CPU可以从这个任务上次暂停的地方继续执行。

  3. 执行新的任务:上述状态恢复完成后,CPU开始执行新的任务。

上下文切换虽然是实现多任务并发的重要机制,但也有其代价。上下文切换会消耗系统资源,尤其是时间和内存。频繁的上下文切换可能会导致CPU利用率下降,因为CPU需要花费时间在任务之间切换,而不是持续执行任务。因此,虽然多线程和多进程可以提高程序的并发性能,但也需要注意避免不必要的上下文切换,以提高程序的整体效率。

2.守护线程和用户线程有什么区别呢?

在Java中,线程可以分为两种类型:守护线程(Daemon Thread)和用户线程(User Thread)。它们之间的主要区别在于它们在程序运行结束时的行为上。

  1. 用户线程:这是程序的正常线程,用于执行程序的主要操作。只要有任何用户线程还在运行,程序就不会终止。换句话说,JVM会等待所有用户线程执行完毕才会关闭。

  2. 守护线程:守护线程主要用于为其他线程或程序提供支持性服务。其特点是,一旦所有用户线程都结束了执行,不管守护线程是否执行完毕,程序都会终止,JVM也随之退出。这意味着,如果程序中只剩下守护线程在运行,JVM就会退出。典型的守护线程包括垃圾回收线程。

设置线程为守护线程的方法是在线程启动之前调用setDaemon(true)方法。一旦线程启动,你就不能更改它的守护状态了。例如:

Thread thread = new Thread(new MyRunnable());
thread.setDaemon(true); // 将线程设置为守护线程
thread.start();

需要注意的是,守护线程不应用于执行核心业务逻辑或执行需要保证完成的操作,因为你无法确保它们会在JVM退出时正常完成执行。它们更适合执行一些后台任务,比如日志监控、垃圾回收等。

3.如何在 Windows 和 Linux 上查找哪个线程cpu利用率最高?

在 Windows 和 Linux 上查找哪个线程的 CPU 利用率最高,可以分别使用这两个操作系统内置的工具或者第三方工具来完成。下面是一些具体的方法:

Windows

在 Windows 上,你可以使用资源监视器(Resource Monitor)或者性能监视器(Performance Monitor)来查看线程的 CPU 利用率。

资源监视器
  1. 打开任务管理器(Task Manager),你可以通过在任务栏上右键点击然后选择“任务管理器”,或者使用快捷键 Ctrl + Shift + Esc
  2. 在任务管理器中,点击“性能”标签页,然后点击底部的“打开资源监视器”链接。
  3. 在资源监视器中,点击“CPU”标签页。这里你可以看到所有进程及其对应线程的 CPU 利用率。
性能监视器
  1. 打开性能监视器,可以通过搜索“性能监视器”来找到并打开它。
  2. 在性能监视器中,你可以添加具体的监视器来详细查看线程的 CPU 利用率。

Linux

在 Linux 上,可以使用 tophtop(一个 top 的增强版,需要单独安装)命令来查看 CPU 利用率最高的线程。

使用 top
  1. 打开终端。
  2. 输入 top 命令并执行。
  3. Shift + H 切换到线程视图,这样你就可以看到各个线程的 CPU 利用率了。
使用 htop
  1. 如果你的系统还没有安装 htop,可以通过包管理器安装。例如,在基于 Debian 的系统上使用 sudo apt-get install htop
  2. 打开终端,输入 htop 并执行。
  3. htop 中,你可以通过 F5 切换到树形视图,以查看进程和线程的层级结构。htop 提供了一个更直观的界面来查看线程的 CPU 利用率。

这些工具和命令可以帮助你监控系统的性能,找出 CPU 利用率最高的线程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/815970.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java:特殊文件(properties,xml)和日志

特殊文件 txt(文本文件) txt文件是一种纯文本文件,用于存储文本信息 优缺点:txt文件简单易用,可以使用任何文本编辑器打开和编辑,但不支持数据类型和结构,所有信息均用纯文本形式保存 适合简单的配置信息存储 properties文件 properties文件是一种键值对文件,用于存储配置…

从零自制docker-10-【cgroup进行容器资源限制】

文章目录 目的导入包的相关公开原则当前进程的挂载信息deferfor scanner.Scan()判断字符串包含新建的cgroup的默认文件cpu相关配置对应到ubuntu 22.04版本的cpu相关配置top注意查看你可使用的cpu注意坑启动后的top查看显示进程使用的cpu序号代码结果 目的 启动容器时通过-mem、…

《每天十分钟》-红宝书第4版-对象、类与面向对象编程(七)

类 之前的几个继承模式,只使用 ECMAScript 5 的特性来模拟类似于类(class-like)的行为。不难看出,各种策略都有自己的问题,也有相应的妥协,而且代码又丑又长。 为了解决这些问题,ECMAScript 6 …

JAVA集合(学习)

1.Java集合框架体系图 集合框架Collection单列集合List 有序,可重复Vector 数组结构,线程安全ArrayList 数组结构,非线程安全LinkedList 链表结构,非线程安全Set 无序,唯一HashSet 哈希表结构LinkedHashSet 哈希表…

Spring Bean作用域

Sping中bean的scope的值可以是singleton、prototype、request、session、global session。默认情况下是singleton。只有在web容器中才能使用request、session、global session。 singleton:单例模式,spring容器中有且仅有一个对象,init方法在创建容器时仅执行一次。关闭容器…

简单几步启用Ubuntu root用户密码登录

Ubuntu默认登录用户为ubuntu,且禁用了root用户使用密码方式登录。 若要开起root用户登录,只需要以下几步: 1.使用ubuntu用户登录Linux服务器。 2.使用sudo修改root用户密码。 sudo passwd root 输入新设置的root用户密码,此时…

Mac下Homebrew更新国内源brew update卡死(完美解决)

先更新下brew 有时brew版本太旧也会有问题 /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" 再更新国内源 #更新Homebrew cd "$(brew --repo)" git remote set-url origin https://mirrors.ustc…

jvisualVM分析jvm内存使用快照dump

服务发生内存溢出,就需要查看服务器上Java服务的jvm堆内存使用情况,可以使用dump命令生成dump文件,然后下载到本地,然后使用jvisualVM工具打开,即可实现可视化分析。 生成dump文件常用的两种方式: 第一种…

6-138 大整数相加

本题要求实现一个函数,实现大整数相加运算。大整数按每4位保存在整数数组中,如果大整数位数不是4的倍数,则将保证低位都按4位一存。如“123456789”保存为1,2345,6789。 函数接口定义: int convert(char a[],int x[]); int add(int x[],int len1,int y[],int len2,int …

[react] useState的一些小细节

1.无限循环 因为setState修改是异步的,加上会触发函数重新渲染, 如果代码长这样 一秒再修改,然后重新触发setTImeout, 然后再触发,重复触发循环 如果这样呢 还是会,因为你执行又会重新渲染 2.异步修改数据 为什么修改多次还是跟不上呢? 函数传参解决 因为是异步修改 ,所以…

代码随想录算法训练营第三十六天| 435. 无重叠区间、 763.划分字母区间、56. 合并区间

435 题目: 给定一个区间的集合 intervals ,其中 intervals[i] [starti, endi] 。返回 需要移除区间的最小数量,使剩余区间互不重叠 。 题目链接:435. 无重叠区间 - 力扣(LeetCode) 思路: …

Nacos 入门篇---服务端如何处理客户端的服务注册请求?(三)

一、引言 ok呀,上个章节我们讲了Nacos客户端的服务自动注册,今天我们来看看服务端接收到了客户端的服务注册请求,服务端都做了哪些事情~ 二、目录 目录 一、引言 二、目录 三、回顾上节内容: 四、Nacos 服务代码入…

工作流引擎项目解析(二)

流程变量设置于获取 Activiti--流程变量_runtimeservice.setvariable-CSDN博客 Process Variables | docs.camunda.org 设置 启动时设置任务完成时设置runtimeService.setvars…()taskservice.setvars…() ProcessEngine processEngine ProcessEngines.getDefaultProcessEn…

python项目练习——24、线旅游预订系统

用户管理功能: 用户注册:用户可以填写用户名和密码进行注册。用户登录:注册过的用户可以使用用户名和密码登录系统。用户资料管理:用户可以查看和编辑自己的个人资料。旅游产品管理功能: 产品列表展示:展示可预订的旅游产品列表。产品搜索:用户可以根据关键字、目的地、…

Nginx 基础应用实战 04 在公网配置配置HTTPS

Nginx 基础应用实战 04 在公网配置配置HTTPS Nginx配置 server {listen 443 ssl;server_name aa.abc.com;ssl_certificate /data/cert/server.crt;ssl_certificate_key /data/cert/server.key;}免费签名 https://freessl.cn 阿里云 腾讯云 Nginx配置 serve…

Springboot整合nacos报错无法连接nacos

报错信息:Nacos com.alibaba.nacos.api.exception.NacosException: Client not connected, current status:STARTING 关于这个报错的原因有很多:如Nacos未启动、网络问题、配置问题、版本不兼容问题等,我的报错原因主要是版本不兼容。 下面…

5.9 mybatis之callSettersOnNulls作用

文章目录 1. 当callSettersOnNullstrue时2. 当callSettersOnNullsfalse时 在mybatis的settings配置参数中有个callSettersOnNulls参数,官方解释为:指定当结果集中值为 null 的时候是否调用映射对象的 setter(map 对象时为 put)方法…

PostgreSQL入门到实战-第三十弹

PostgreSQL入门到实战 PostgreSQL教程网站官网地址PostgreSQL概述更新计划 PostgreSQL教程网站 https://www.postgresqltutorial.com/ 官网地址 声明: 由于操作系统, 版本更新等原因, 文章所列内容不一定100%复现, 还要以官方信息为准 https://www.postgresql.org/PostgreS…

【系统分析师】计算机网络

文章目录 1、TCP/IP协议族1.1 DHCP协议1.2 DNS协议1.3网络故障诊断 2、网路规划与设计2.1逻辑网络设计2.2物理网络设计2.3 分层设计 3、网络接入3.1 接入方式3.2 IPv6地址 4、综合布线技术5、物联网5.1物联网概念与分层5.2 物联网关键技术 6、云计算7、网络存储技术&#xff08…

neo4j使用详解(结尾、neo4j的java driver使用模板及工具类——<可用于生产>)

Neo4j系列导航: neo4j安装及简单实践 cypher语法基础 cypher插入语法 cypher插入语法 cypher查询语法 cypher通用语法 cypher函数语法 neo4j索引及调优 neo4j java Driver等更多 1. 简介 本文主要是java使用neo4j driver操作neo4j的模板项目及非常有用的工具类,主要包括: 图…