《现代体系结构上的UNIX系统:内核程序员的对称多处理和缓存技术(修订版)》——1.4 上下文切换

简介: 在同一个进程内从一个线程切换到另一个线程的操作称为线程切换(thread switch)。因为进程不变,所以不需要改变地址空间的映射关系。只有上一段话中列出的寄存器和其他项需要保存和恢复。和进程的上下文切换相比,线程切换较少的开销是使用线程的另一个优点。

本节书摘来自异步社区《现代体系结构上的UNIX系统:内核程序员的对称多处理和缓存技术(修订版)》一书中的第1章,第1.4节,作者:【美】Curt Schimmel著,更多章节内容可以访问云栖社区“异步社区”公众号查看

1.4 上下文切换

内核从执行一个进程转为执行另一个进程的操作称为上下文切换(context switch)。这项操作包括保存当前进程的状态以便在将来可以恢复、选择一个要执行的新进程,以及把所保存的新进程的状态载入到硬件中。进程在上下文切换时必须保存和恢复的最少状态是CPU寄存器的内容、PC(程序计数器)、栈指针、条件码,以及虚拟地址空间的映射关系。

在同一个进程内从一个线程切换到另一个线程的操作称为线程切换(thread switch)。因为进程不变,所以不需要改变地址空间的映射关系。只有上一段话中列出的寄存器和其他项需要保存和恢复。和进程的上下文切换相比,线程切换较少的开销是使用线程的另一个优点。总体而言,本书所介绍的主题都不需要考虑使用线程切换。

如前所述,每个进程都获得了一个独立的虚拟地址空间,这不但给它一个假象,以为它自己独自运行在计算机上,并且把它隔离开来,不受其他进程的干扰。在线程切换期间选择一个要执行的新进程时,必须彻底消除原来进程的地址空间映射,从而让新进程不能访问它。随后,新进程的地址空间被映射进来,从而能够被该进程访问。

根据所用的特定硬件,可能要保存和恢复其他类型的状态。例如,高速缓存可能需要在上下文切换时根据它们的实现进行管理(这是接下来几章讨论的主题)。内核必须确保一个进程的上下文所要求的所有部分都被保存下来,以便在将来的某个时刻可以恢复它,从而可以继续执行,就好像从未发生过上下文切换一样。这是内核保持每个进程都独自在系统上执行的假象这一任务的一个重要方面。

相关文章
|
5月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
108 6
|
3月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
327 78
|
3月前
|
数据采集 存储 缓存
如何使用缓存技术提升Python爬虫效率
如何使用缓存技术提升Python爬虫效率
|
3月前
|
存储 缓存 负载均衡
从零到一:分布式缓存技术初探
分布式缓存通过将数据存储在多个节点上,利用负载均衡算法提高访问速度、降低数据库负载并增强系统可用性。常见产品有Redis、Memcached等。其优势包括性能扩展、高可用性、负载均衡和容错性,适用于页面缓存、应用对象缓存、状态缓存、并行处理、事件处理及极限事务处理等多种场景。
287 1
|
5月前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
157 15
Android 系统缓存扫描与清理方法分析
|
5月前
|
存储 缓存 数据库
缓存技术有哪些应用场景呢
【10月更文挑战第19天】缓存技术有哪些应用场景呢
|
5月前
|
存储 缓存 运维
缓存技术有哪些优缺点呢
【10月更文挑战第19天】缓存技术有哪些优缺点呢
|
6月前
|
存储 缓存 NoSQL
解决Redis缓存击穿问题的技术方法
解决Redis缓存击穿问题的技术方法
109 2
|
6月前
|
存储 缓存 Java
在Spring Boot中使用缓存的技术解析
通过利用Spring Boot中的缓存支持,开发者可以轻松地实现高效和可扩展的缓存策略,进而提升应用的性能和用户体验。Spring Boot的声明式缓存抽象和对多种缓存技术的支持,使得集成和使用缓存变得前所未有的简单。无论是在开发新应用还是优化现有应用,合理地使用缓存都是提高性能的有效手段。
92 1
|
7月前
|
缓存 NoSQL Linux
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据
180 1
【Azure Redis 缓存】Windows和Linux系统本地安装Redis, 加载dump.rdb中数据以及通过AOF日志文件追加数据