猫头鹰OS面试指南

本文深入探讨了操作系统中的关键概念,包括进程与线程的区别,上下文切换的成本,死锁的产生条件及解决策略,如银行家算法。此外,还介绍了进程的切换步骤和各种调度算法,如FCFS、SJF、时间片轮转等,以及各自的优缺点。同时,阐述了虚拟内存的实现方式——分页和分段,并分析了它们的优劣。最后,讨论了进程间的通信机制,如共享内存、管道、socket和信号量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,进程是资源分配的最小单位,线程是系统调度的最小单位

2,进程切换和线程切换,上下文切换
从切换成本出发
进程切换相当于线程切换(PC指针)+内存切换。
有可能会引出内核级线程和用户级线程,要会区别。

3,死锁
产生条件:多个进程各自占有资源,又各自需要申请资源,造成环路等待的情况。
处理:
一次性申请所有资源->对资源要求高
资源有序申请->对算法要求高
引出银行家算法例子。

4,进程如何切换
先保存当前进程的资源->放入寄存器中
通过调度算法获取下一个进程->使用PC指针
切换到下一个进程
延伸到调度算法
先到先得算法+短作业优先+时间片调转+轮询,要每个都能举一个例子和各自优缺点

5,os的内存管理
Q:如何实现虚拟内存?
分页和分段
Q:介绍分页和分段的优缺点

6,进程如何通信
共享内存,管道,socket,信号量

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值