博客
关于我
计算机启动过程
阅读量:295 次
发布时间:2019-03-01

本文共 667 字,大约阅读时间需要 2 分钟。

计算机启动过程

启动是一个看似矛盾却又必须的过程:计算机启动后才能运行程序,启动程序才能让计算机正常工作。为了解决这一矛盾,计算机科学家设计了一个启动机制,使得通电后计算机能够自动执行必要的程序。

启动过程的起点是BIOS(Basic Input and Output System),这是计算机最早被启动的程序。启动时,BIOS首先检查计算机是否能够正常运行。这包括对系统硬件的初始化和检查,确保所有必要的硬件设备能够正常工作。

完成初步检查后,BIOS会寻找下一个启动程序。这个程序通常存储在硬盘的第一个扇区中。在32位系统中,这个扇区的大小为512字节。这个扇区的最后两个字节通常是0x55和0xAA,表示该扇区对应的设备可以被启动。

这个扇区被称为MBR(Master Boot Record)。它包含了启动系统所需的关键信息。MBR的前446个字节用于启动操作系统,接下来的64字节是分区表,用于描述硬盘上的各个分区。最后两个字节是固定的0x55和0xAA,标识该扇区为启动扇区。

分区表的作用是将硬盘分成多个操作系统的分区。每个分区表项包含一个分区的信息,包括起始位置、结束位置、文件系统类型等。由于每个分区表项只有64字节,且每个分区表最多包含4项,因此一个硬盘最多可以分为4个一级分区。

当计算机读取到MBR后,会启动相应的bootloader程序。bootloader的主要任务是将操作系统的内核加载到内存中,然后运行操作系统的入口程序。经过这一步,操作系统就正式启动了,系统进程逐步运行,直到整个系统环境准备就绪。

转载地址:http://pyao.baihongyu.com/

你可能感兴趣的文章
Objective-C实现Boyer-Moore字符串搜索算法(附完整源码)
查看>>
Objective-C实现BP误差逆传播算法(附完整源码)
查看>>
Objective-C实现breadth First Search广度优先搜索算法(附完整源码))
查看>>
Objective-C实现BreadthFirstSearch广度优先搜索算法(附完整源码)
查看>>
Objective-C实现BreadthFirstShortestPath广度优先最短路径算法(附完整源码)
查看>>
Objective-C实现bubble sort冒泡排序算法(附完整源码)
查看>>
Objective-C实现bucket sort桶排序算法(附完整源码)
查看>>
Objective-C实现Burke 抖动算法(附完整源码)
查看>>
Objective-C实现Burrows-Wheeler 算法(附完整源码)
查看>>
Objective-C实现CaesarsCiphe凯撒密码算法(附完整源码)
查看>>
Objective-C实现calloc函数功能(附完整源码)
查看>>
Objective-C实现canny边缘检测算法(附完整源码)
查看>>
Objective-C实现cartesianProduct笛卡尔乘积算法(附完整源码)
查看>>
Objective-C实现check strong password检查密码强度算法(附完整源码)
查看>>
Objective-C实现chudnovsky algorithm楚德诺夫斯基算法(附完整源码)
查看>>
Objective-C实现CIC滤波器(附完整源码)
查看>>
Objective-C实现circle sort圆形排序算法(附完整源码)
查看>>
Objective-C实现CircularQueue循环队列算法(附完整源码)
查看>>
Objective-C实现clearBit清除位算法(附完整源码)
查看>>
Objective-C实现climbStairs爬楼梯问题算法(附完整源码)
查看>>