首页 > 其他分享 >什么是上下文切换-第二篇

什么是上下文切换-第二篇

时间:2023-02-20 19:44:47浏览次数:44  
标签:状态 WAITING 线程 切换 上下文 第二篇 CPU

1.上下文切换的含义

  其实在单个处理器的时期,操作系统就能处理多线程并发任务。处理器给每个线程分配 CPU 时间片(Time Slice),线程在分配获得的时间片内执行任务。

  CPU 时间片是 CPU 分配给每个线程执行的时间段,一般为几十毫秒。在这么短的时间内线程互相切换,我们根本感觉不到,所以看上去就好像是同时进行的一样。

  时间片决定了一个线程可以连续占用处理器运行的时长。当一个线程的时间片用完了,或者因自身原因被迫暂停运行了,这个时候,另外一个线程(可以是同一个线程或者其它进程的线程)就会被操作系统选中,来占用处理器。这种一个线程被暂停剥夺使用权,另外一个线程被选中开始或者继续运行的过程就叫做上下文切换(Context Switch)。

  

  具体来说,一个线程被剥夺处理器的使用权而被暂停运行,就是“切出”;一个线程被选中占用处理器开始或者继续运行,就是“切入”。在这种切出切入的过程中,操作系统需要保存和恢复相应的进度信息,这个进度信息就是“上下文”了。

  那上下文都包括哪些内容呢?具体来说,它包括了寄存器的存储内容以及程序计数器存储的指令内容。CPU 寄存器负责存储已经、正在和将要执行的任务,程序计数器负责存储 CPU 正在执行的指令位置以及即将执行的下一条指令的位置。

  在当前 CPU 数量远远不止一个的情况下,操作系统将 CPU 轮流分配给线程任务,此时的上下文切换就变得更加频繁了,并且存在跨 CPU 上下文切换,比起单核上下文切换,跨核切换更加昂贵。

 

2.什么原因会导致上下文切换

  在操作系统中,上下文切换的类型还可以分为进程间的上下文切换和线程间的上下文切换。而在多线程编程中,我们主要面对的就是线程间的上下文切换导致的性能问题,下面我们就重点看看究竟是什么原因导致了多线程的上下文切换。开始之前,先看下系统线程的生命周期状态。

  

  结合图示可知,线程主要有 NEW、RUNABLE、BLOCKED、WAITING、TIMED_WAITING、TERMINADTED 等 6 种状态。

  在这个运行过程中,线程由 RUNNABLE 转为非 RUNNABLE 的过程就是线程上下文切换。抛开新建和死亡状态,从上面的图中可以看出:上下文切换主要发生在RUNABLE状态和BLOCKED、WAITING、TIMED_WAITING这些状态的互相转换之间。

  举个列子,一个线程的状态由 RUNNING 转为 BLOCKED ,再由 BLOCKED 转为 RUNNABLE ,然后再被调度器选中执行,这就是一个上下文切换的过程。

  通过线程的运行状态以及状态间的相互切换,我们可以了解到,多线程的上下文切换实际上就是由多线程两个运行状态的互相切换导致的

  根据上面的分析,我们可以总结出导致上下文切换的几个原因:

  • CPU时间片用完,导致正常的上下文切换;
  • sleep()、wait()、yield()、join()、park()、synchronized、lock这些方法或者关键字会导致线程状态的转换,所以这些方法的调用也会导致上下文的切换;(需要注意的是这些方法的调用虽然后导致上下文切换,但是并不会占用CPU资源,也就是说并不会提升CPU使用率);
  • 另外,JVM虚拟机在进行垃圾回收时,会进行STOP-THE-WORLD,这个操作会暂停所有Java线程,垃圾收集完之后线程再进入工作状态,其实这个也是一种上下文切换操作。

 

3.怎么查看系统上下文切换的数据

  分线程的状态

  第一步:用jstack命令dump线程信息,看看pid为3117的进程里的线程都在做什么。sudo -u admin /opt/ifeve/java/bin/jstack 31177 >/home/tengfei.fangtf/dump17

  第二步:统计所有线程分别处于什么状态,发现300多个线程处于WAITING(onobject-monitor)状态。

[zx@zx ~]$ grep java.lang.Thread.State dump17 | awk '{print 223445}' | sort | uniq -c
39 RUNNABLE
21 TIMED_WAITING(onobjectmonitor)
6 TIMED_WAITING(parking)
51 TIMED_WAITING(sleeping)
305WAITING(onobjectmonitor)
3 WAITING(parking)

  分析上面的线程的每个状态是因为什么原因造成的。

  第三步:打开dump文件查看处于WAITING(onobjectmonitor)的线程在做什么。

  第四步:减少JBOSS的工作线程数,找到JBOSS的线程池配置信息,将maxThreads降到100。

 

  转载: https://blog.csdn.net/xintingandzhouyang/article/details/119300895

标签:状态,WAITING,线程,切换,上下文,第二篇,CPU
From: https://www.cnblogs.com/lizexiong/p/17138686.html

相关文章

  • mapbox 之 switch map 图层切换
    由于最近在mapbox-extensions中完善的功能越来越多,尤其是SwitchMapControl这个控件,所以单开一篇向大家介绍一下。先看一下效果:功能包括(整体模仿google):卫星地图和电......
  • 多线程频繁上下文切换
    什么是上下文切换在单核cpu中,多线程的执行是通过cpu的时间片分配,每个线程会分配到一个时间片,循环执行这些线程,线程时间片消耗完了就会进入等待状态,直到分配到新的时间......
  • SVN 之切换账号
     简单来说两步就搞定了 第一步删除已缓存的数据 第二步输入要切换账号密码 具体步骤图解如下:第一步:点击TortoiseSVN找到设置   点击已保存数据点击清除......
  • 滑动silder切换图片,向上弹出设置层
     ////HelloWorldViewController.h//图片浏览////Createdbymahongminon14-5-15.//Copyright(c)2014年mahongmin.Allrightsreserved.//#import<UIKit/U......
  • 安装n 以及使用n 切换node版本
    使用n安装并且切换node版本全局安装n使用n安装某个node版本n切换node版本全局安装nnpminstall-gn1使用n安装某个node版本安装最新稳定版node:nstable安装最新版本nod......
  • Linux-485收发切换延迟的解决方法 ——转载
     【前言】本文引用各种资料甚多,而引用出处标明并不详细,若有侵权,请联系删除。转载请注明出处:https://www.cnblogs.com/leisure_chn/p/10381616.html一、问题描述R......
  • .NET Core中批量注册上下文
    1.定义一个静态类HostBuilderExtend作为扩展1publicstaticclassHostBuilderExtend2{3publicstaticvoidRegister(thisWebApplicationBuilder......
  • 进程状态的切换
      当创建一个子进程后,该进程会进入就绪状态,再根据系统的调度,获得时间片,就进入运行状态,在运行状态的进程调用return等进程就结束了;如果在运行状态的进程调用read、write......
  • SpringBoot 多环境切换
    日常开发中一般都会有三个不同的环境,分别是开发环境(dev),测试环境(test)和生产环境(prod),不同的环境各种配置都不相同,比如数据库配置,服务器端口等等。SpringBoot多环境配置Sp......
  • AntDesign中card卡片动态添加bodystyle样式,实现body切换
    业务效果核心代码<template><a-layoutclass="layout"><a-layout-headerclass="header"style="height:50px"><divclass="wrappercontent">......