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

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

计算机启动过程

本文主要参考

  1. 阮一峰的博客:http://www.ruanyifeng.com/blog/2013/02/booting.html
  2. 深入解析linux0.11

计算机的启动是一个很矛盾的事情:在计算机启动后计算机才能正常运行程序,计算机启动又需要运行程序。

为了解决这个矛盾,计算机科学家把开机程序放到计算机的某个地方,计算机通电后,第一件事情就是读取这个程序。

这个程序被称之为BIOS,Basic Input and Output System

BIOS首先会检查这台计算机能不能被启动。它将检查计算机系统的各个硬件并对它们进行初始化。

如果能正常启动,那么它将寻找下一阶段的启动程序,并且把下一阶段的启动程序转交给它。BIOS有一个存储外部存储设备的排序,排在前面的就是优先转交控制权的程序。

接下来,计算机会读取这个设备的第一个扇区。在32位的系统里,这个扇区的大小为512字节。

若该扇区的最后两个字节是0x55、0xAA,则代表该设备可以被启动

这512字节称之为MBR,Master boot record

它的主要作用是告诉计算机操作系统在哪个地方。
它由三个部分组成,前446个字节用来调用操作系统,第447到第510个字节为分区表,最后两个字节就是0x55和0xAA

分区表的作用是将操作系统分成若干个区。

每个分区表的长度只有64字节,里面只能分为4项,因此一个硬盘最多只有4个一级分区。

接下来,计算机将运行bootloader程序,启动操作系统,将操作系统的内核载入内存,然后运行操作系统的入口程序。操作系统启动完成。

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

你可能感兴趣的文章
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
MySQL Cluster与MGR集群实战
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>