常用内核架构

 

本文分享自天翼云开发者社区常用内核架构》,作者:JackW

 

宏内核

应用程序调用内存分配的 API(应用程序接口)函数。

处理器切换到特权模式,开始运行内核代码。

内核里的内存管理代码按照特定的算法,分配一块内存。

把分配的内存块的首地址,返回给内存分配的 API 函数。

内存分配的 API 函数返回,处理器开始运行用户模式下的应用程序,应用程序就得到了一块内存的首地址,并且可以使用这块内存了。

特点:功能耦合,效率高;但是开发一个新的功能也得重新编译、链接、安装内核,因为它没有模块化,没有扩展性、没有移植性,高度耦合在一起,一旦其中一个组件有漏洞,内核中所有的组件可能都会出问题。

常用内核架构

微内核

应用程序发送内存分配的消息,这个发送消息的函数是微内核提供的,相当于系统 API,微内核的 API(应用程序接口)相当少,极端情况下仅需要两个,一个接收消息的 API 和一个发送消息的 API。

处理器切换到特权模式,开始运行内核代码。

微内核代码让当前进程停止运行,并根据消息包中的数据,确定消息发送给谁,分配内存的消息当然是发送给内存管理服务进程。

内存管理服务进程收到消息,分配一块内存。

内存管理服务进程,也会通过消息的形式返回分配内存块的地址给内核,然后继续等待下一条消息。

微内核把包含内存块地址的消息返回给发送内存分配消息的应用程序。

处理器开始运行用户模式下的应用程序,应用程序就得到了一块内存的首地址,并且可以使用这块内存了。

常用内核架构 

特点:微内核牺牲一定性能,具有不少优点,首先,系统结构相当清晰利于协作开发。其次,系统有良好的移植性,微内核代码量非常少,就算重写整个内核也不是难事。最后,微内核有相当好的伸缩性、扩展性,因为那些系统功能只是一个进程,可以随时拿掉一个服务进程以减少系统功能,或者增加几个服务进程以增强系统功能。

 

Darwin-XUN 内核

Darwin是苹果公司2000年开发的开源OS。集成了卡耐基梅隆大学的微内核Mach和伯克利大学的类Unix操作系统,后者提供一整套的操作系统服务。

常用内核架构

 

Windows NT(new Technology)

微软为了获得市场,从不稳定的Windows3.1、95/98、ME之后推出NT,后续的XP更是成为其商业巅峰。

常用内核架构

 

 

总结

Linux 性能良好,结构异常复杂,不利于问题的排查和功能的扩展,而 Darwin-XNU 和 Windows 结构良好,层面分明,利于功能扩展,不容易产生问题且性能稳定。

 

原文链接:https://www.cnblogs.com/developer-tianyiyun/p/17337722.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:常用内核架构 - Python技术站

(0)
上一篇 2023年4月20日
下一篇 2023年4月23日

相关文章

  • 用C语言实现单链表的各种操作(一)

    “用C语言实现单链表的各种操作(一)”详细介绍了如何通过C语言来实现单链表的常见操作。下面,我会结合该文章的内容,对其进行完整攻略的介绍。 文章的主要内容包括:单链表的定义、单链表的初始化、判断单链表是否为空、获取单链表中元素个数、在链表开头插入元素、在链表末尾插入元素、在链表中间插入元素、删除链表中指定元素、在链表中查找指定元素、链表的反转以及链表的销毁。…

    数据结构 2023年5月17日
    00
  • Java数据结构之图的基础概念和数据模型详解

    Java数据结构之图的基础概念和数据模型详解 简介 图是一种非常重要的数据结构,在计算机科学和实际应用中广泛使用。比如搜索引擎中的网页之间的链接关系就可以用图来表示和处理。在本文中,我们将详细讲解图的基础概念和数据模型。同时,我们将通过两个实例来进一步说明图的应用。 图的基础概念 什么是图 图是由若干个节点(顶点)和连接节点的边组成的一种数据结构。一个图可以…

    数据结构 2023年5月17日
    00
  • Python实现归一化算法详情

    下面是关于“Python实现归一化算法详情”的完整攻略。 1. 归一化算法理论基础 归一化是一种常用的预处理技术,它的基本思想是将数据按照一定比例缩放到定的范围内,以便更好地进行分析处理。常用的归一化方法有两种,分别是最小-最大归一化和Z-score归一化。 1.1 最小-最大归一化 最小-最大归一化是一种常用的归一化方法,它的基本思想是将数据按照定的比例缩…

    python 2023年5月13日
    00
  • Lua中使用table实现的其它5种数据结构

    Lua中使用table可以实现多种数据结构,除了Lua原生支持的数组、哈希表之外,我们还可以用table来实现其他五种数据结构,这些数据结构包括集合(Set)、队列(Queue)、双端队列(deque)、堆栈(stack)以及链表(List)。 Set 集合数据结构中的元素是无序的、不重复的。使用table来实现集合数据结构,可以将元素作为table的key…

    数据结构 2023年5月17日
    00
  • python人工智能深度学习算法优化

    下面是详细讲解“Python人工智能深度学习算法优化”的完整攻略,包括算法优化方法、Python实现和两个示例。 算法优化方法 深度学习算法优化是通过改进算法的训练过程,提高模型的性能和泛化能力。常见的深度学习算法优化方法包括以下几种: 1. 正则化 正则化是一种常用的深度学习算法优化方法,其主要思想是对模型参数进行约束,避免模型过拟合。常见的正则化方法包括…

    python 2023年5月14日
    00
  • python实现Simhash算法

    下面是详细讲解“Python实现Simhash算法”的完整攻略,包含两个示例说明。 Simhash算法 Simhash算法是一种用于计算文本相似度的算法。它将文本转换为一个固定长度的二进制向量,并使用哈希函数计算向量的哈希值。Simhash算法的基本思想是将文本中的每个特征转换为一个二进制位,并使用加权函数计算每个特征的权重。然后,将所有特征的加权和转换为一…

    python 2023年5月14日
    00
  • Python实现迪杰斯特拉算法过程解析

    Python实现迪杰斯特拉算法过程解析 迪杰斯特拉算法是一种用于解决带权图中单源最短路径问题的贪心算法。它的本思想是从起点开始,逐步扩展其他节点,每次选择当前距离起点最近的节点,并更新与该节点相邻的节点距离。本文将详细介绍Python实现迪杰斯特拉算法的过程,并提供两个示例说明。 迪杰斯特算的实现 1. 初始化 首先,我们需要初始化一个距离列表和一个已访问列…

    python 2023年5月13日
    00
  • 详解普里姆算法原理与使用方法

    什么是普里姆算法 普里姆算法是一种贪心算法,用于求解加权连通图的最小生成树问题。它的基本思想是从某一点开始,不断选择与当前集合(生成树)连通而且边权最小的点,直到覆盖所有节点。 使用方法 以下为普里姆算法的具体步骤: 选择一个起点,将其标记为已经考虑过的节点,加入到当前集合中。 按照节点与集合的连接边权从小到大的顺序,将这些连接该集合的边加入到一个备选集合中…

    算法 2023年3月27日
    00
合作推广
合作推广
分享本页
返回顶部