博客
关于我
计算机启动过程
阅读量: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/

你可能感兴趣的文章
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>