博客
关于我
计算机启动过程
阅读量: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 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>