【C++上岸】C++常见面试题目--操作系统篇(第二十九期)

🚀 C++面试宝典:操作系统核心问题全解析

🌟 适用人群:即将面试的C++开发者 | 校招/社招冲刺 | 操作系统知识梳理


文章目录

      • [🚀 C++面试宝典:操作系统核心问题全解析](#🚀 C++面试宝典:操作系统核心问题全解析)
        • [1. **了解进程调度机制吗?**](#1. 了解进程调度机制吗?)
        • [2. **什么是实时系统?**](#2. 什么是实时系统?)
        • [3. **进程和线程创建/撤销发生了什么?**](#3. 进程和线程创建/撤销发生了什么?)
        • [4. **悲观锁 vs 乐观锁**](#4. 悲观锁 vs 乐观锁)
        • [5. **僵尸进程 vs 孤儿进程**](#5. 僵尸进程 vs 孤儿进程)
        • [6. **线程间同步方式**](#6. 线程间同步方式)
        • [7. **银行家算法**](#7. 银行家算法)
        • [8. **内存管理到底是干什么的?**](#8. 内存管理到底是干什么的?)
        • [9. **RR调度算法**](#9. RR调度算法)
        • [10. **动态库 vs 静态库**](#10. 动态库 vs 静态库)

1. 了解进程调度机制吗?

进程调度是操作系统的"交通警察"🚦,负责分配CPU时间给就绪进程。常见算法:

  • 先来先服务 (FIFO):简单粗暴,但可能导致短作业饿死
  • 短作业优先 (SJF):优化平均等待时间,但需预知运行时长
  • 优先级调度 :按优先级分配,高优先级可抢占(如 p r i o r i t y = r u n _ t i m e m a x _ r u n _ t i m e priority = \frac{run\_time}{max\_run\_time} priority=max_run_timerun_time)
  • 多级反馈队列:综合优先级+时间片轮转,Linux常用策略

💡 面试点睛:反问面试官"您想了解具体算法实现还是应用场景?"体现深度思考!


2. 什么是实时系统?

🕒 核心特征时限保障!分两类:

  • 硬实时:超时即致命(如火箭控制🔥)
  • 软实时:超时可容忍(如视频流延迟)
cpp 复制代码
// 伪代码示例:实时任务调度
if (task.miss_deadline()) {
    emergency_handle(); // 硬实时响应
}

3. 进程和线程创建/撤销发生了什么?
操作 进程 线程
创建 分配PCB、独立地址空间 共享进程资源,仅分配TCB
撤销 回收所有资源(内存、文件) 仅释放栈、寄存器等私有资源

⚠️ 注意:线程撤销时需同步资源(否则死锁警告!)


4. 悲观锁 vs 乐观锁
  • 悲观锁 :默认会冲突,先加锁再操作(如mutex.lock()
  • 乐观锁:默认无冲突,提交时检测版本(如CAS操作):
cpp 复制代码
bool CAS(int *addr, int expect, int new_val) {
    if(*addr == expect) { 
        *addr = new_val; 
        return true;
    }
    return false;
}

🧠 场景:高并发读用乐观锁,高并发写用悲观锁!


5. 僵尸进程 vs 孤儿进程
类型 成因 危害 解决
僵尸进程 🧟 父进程未回收子进程退出状态 占用PID资源 wait()系统调用
孤儿进程 👶 父进程先退出 无害(被init进程收养) 自动回收

6. 线程间同步方式
  • 互斥锁pthread_mutex_lock()
  • 条件变量pthread_cond_wait() + 信号机制
  • 信号量sem_wait()控制资源计数
  • 屏障pthread_barrier_wait()同步多个线程

🔐 死锁预防:固定加锁顺序 + 超时机制!


7. 银行家算法

核心思想:像银行放贷一样谨慎分配资源💼


进程请求资源
是否安全?
分配
阻塞

安全状态检测公式
A v a i l a b l e ≥ N e e d i ∀ i Available \geq Need_i \quad \forall i Available≥Needi∀i


8. 内存管理到底是干什么的?

四大核心功能:

  1. 虚拟内存:让程序以为独占内存(页表映射📄)
  2. 分页/分段:物理内存逻辑切块
  3. 分配/回收malloc()底层靠brk()mmap()
  4. 保护:防止越界访问(段错误警告!)

9. RR调度算法

轮转时间片⚙️:每个进程固定时长(如10ms),超时即放回队列尾。

  • 优点:公平性强
  • 缺点 :上下文切换开销大
    吞吐量 = 总进程数 平均周转时间 吞吐量 = \frac{总进程数}{平均周转时间} 吞吐量=平均周转时间总进程数

10. 动态库 vs 静态库
特性 静态库 (.a/.lib) 动态库 (.so/.dll)
链接时机 编译时 运行时
体积 大(代码重复) 小(共享代码)
更新 需重新编译 热更新🆕
示例 g++ -static main.cpp -lhello g++ main.cpp -lhello

💎 结语 :啃透这些题,操作系统面试直接拿捏!🎯
🔥 下期预告:《操作系统深潜》+ 内存管理剖析!

(表情包彩蛋🎁:面试官问倒你时 → 🤯;答对时 → 🚀💥)

相关推荐
小肝一下1 小时前
每日两道力扣,day5
数据结构·c++·算法·leetcode·职场和发展·hot100
OOJO5 小时前
c++---list介绍
c语言·开发语言·数据结构·c++·算法·list
会编程的土豆8 小时前
【数据结构与算法】动态规划
数据结构·c++·算法·leetcode·代理模式
棉花骑士8 小时前
【AI Agent】面向 Java 工程师的Claude Code Harness 学习指南
java·开发语言
爱敲代码的小鱼8 小时前
springboot(2)从基础到项目创建:
java·spring boot·spring
迈巴赫车主9 小时前
蓝桥杯19724食堂
java·数据结构·算法·职场和发展·蓝桥杯
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 78. 子集 | C++ 回溯算法题解
c++·算法·leetcode
所以遗憾是什么呢?10 小时前
【题解】Codeforces Round 1081 (Div. 2)
数据结构·c++·算法·acm·icpc·ccpc·xcpc
i220818 Faiz Ul10 小时前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
白藏y10 小时前
【C++】muduo接口补充
开发语言·c++·muduo