常考计算机操作系统面试习题(四)

news2025/3/31 11:29:44

目录

1. Peterson 算法伪代码

2. 信号量生产者消费者问题分析

3. 注释 Peterson 主函数并分析输出结果

4. 用 fork 创建子进程的程序


1. Peterson 算法伪代码

题目:

写出 Peterson 算法的伪代码。

参考答案:

// 定义变量
boolean flag[2];     // 表示每个线程是否希望进入临界区
int turn;            // 表示轮到哪个线程进入临界区

// 线程 i 的代码
do {
    flag[i] = true;  // 表示线程 i 希望进入临界区
    turn = j;        // 将权利让给线程 j
    while (flag[j] && turn == j) {
        // 等待线程 j 完成临界区
    }
    // 临界区
    // ...
    flag[i] = false; // 离开临界区
    // 剩余区
    // ...
} while (true);

说明:

Peterson 算法是用于两个线程的同步算法,保证了互斥和死锁避免。

  • flag[i] 表示线程 i 是否希望进入临界区。

  • turn 变量表示当前轮到哪个线程进入临界区,确保不会发生竞争条件。

2. 信号量生产者消费者问题分析

题目:

注释以下代码,并说明三个信号量的含义,以及 A 和 B 哪个是生产者进程,哪个是消费者进程。

semaphore full = 0, empty = n, mutex = 1;

A: 
do {
    … produce an item in nextp …
    wait(empty);
    wait(mutex);
    add nextp to buffer;
    signal(mutex);
    signal(full);
} while (1);

B: 
do {
    wait(full);
    wait(mutex);
    … remove an item from buffer to nextc …
    signal(mutex);
    signal(empty);
    … consume the item in nextc …
} while (1);

参考答案:

注释代码:

semaphore full = 0;    // 表示缓冲区中的产品数,初始值为 0。
semaphore empty = n;   // 表示缓冲区的空位数,初始值为 n(缓冲区大小)。
semaphore mutex = 1;   // 用于实现对缓冲区操作的互斥访问,初始值为 1。

进程 A 是生产者:

  • produce an item in nextp; 生产一个产品并将其存储在 nextp

  • wait(empty); 确保缓冲区有空位可以存放新产品。

  • wait(mutex); 确保对缓冲区的互斥访问。

  • add nextp to buffer; 将产品添加到缓冲区。

  • signal(mutex); 释放对缓冲区的互斥访问。

  • signal(full); 增加缓冲区中产品的计数。

进程 B 是消费者:

  • wait(full); 确保缓冲区中有可供消费的产品。

  • wait(mutex); 确保对缓冲区的互斥访问。

  • remove an item from buffer to nextc; 从缓冲区中取出产品到 nextc

  • signal(mutex); 释放对缓冲区的互斥访问。

  • signal(empty); 增加缓冲区的空位计数。

  • consume the item in nextc; 消费产品。

3. 注释 Peterson 主函数并分析输出结果

题目:

注释以下 Peterson 主函数的每行程序,并分析程序可能的输出结果。

boolean flag[2];
flag[0] = false;
flag[1] = false;
int turn;

do {
    flag[i] = true;
    turn = j;
    while (flag[j] && turn == j) {}
    // 临界区
    flag[i] = false;
    // 剩余区
} while (1);

参考答案:

注释代码:

boolean flag[2];        // 定义两个标志位,用于表示线程是否希望进入临界区。
flag[0] = false;        // 初始化标志位,表示线程 0 初始时不希望进入临界区。
flag[1] = false;        // 初始化标志位,表示线程 1 初始时不希望进入临界区。
int turn;               // 定义变量,用于指示当前轮到哪个线程进入临界区。
flag[i] = true;         // 线程 i 表示希望进入临界区。
turn = j;               // 将优先权交给线程 j。
while (flag[j] && turn == j) {}  // 如果线程 j 也希望进入临界区且优先级是 j,则等待。
// 临界区:执行线程 i 的临界区代码。
flag[i] = false;        // 线程 i 退出临界区。
// 剩余区:线程 i 执行非临界区代码。

程序输出分析:

  • Peterson 算法保证了互斥性:只有一个线程能进入临界区,两个线程不会同时进入临界区。

  • 死锁避免:通过 turn 变量的使用,确保没有线程因互相等待而永远阻塞。

  • 饥饿避免:因为 turn 变量的轮换机制,确保了每个线程都会有机会进入临界区。

4. 用 fork 创建子进程的程序

题目:

写一个程序,完成以下功能:用 fork 创建子进程,若失败,输出 “failed”,程序退出;在子进程中输出 “child”;在父进程中等待子进程返回后,输出 “parent”。

参考答案:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/wait.h>

int main() {
    pid_t fpid;  // 定义进程号变量
    fpid = fork();  // 创建子进程

    if (fpid < 0) {  // fork 返回值小于 0 表示创建失败
        printf("failed\n");
        exit(-1);  // 退出程序
    } else if (fpid == 0) {  // fork 返回值等于 0 表示当前是子进程
        printf("child\n");
    } else {  // fork 返回值大于 0 表示当前是父进程
        wait(NULL);  // 等待子进程结束
        printf("parent\n");
    }

    return 0;
}

程序运行结果:

  • 如果 fork() 成功,输出:
    child
    parent
    
  • 如果 fork() 失败,输出:
    failed
    

说明:

  • fork() 用于创建子进程,子进程从 fork() 返回点开始执行。

  • 父进程和子进程的区别是 fork() 的返回值不同。

  • wait() 使父进程等待子进程结束后再继续执行。

 配套学习:

面试计算机操作系统解析(一中)-CSDN博客

常考计算机操作系统面试习题(一下)-CSDN博客

常考计算机操作系统面试习题(二)(上)-CSDN博客

常考计算机操作系统面试习题(二)(中)-CSDN博客

常考计算机操作系统面试习题(二)(下)-CSDN博客

常考计算机操作系统面试习题(三上)-CSDN博客

常考计算机操作系统面试习题(三下)-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2323338.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 中的 AOP:实现日志记录与性能监控

<前文回顾> 点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId12907601&sharereferPC&sharesourceFoyoDesigner&sharefromfrom_link <今日更新> 一、开篇整…

多模态大模型训练范式演进与前瞻

本文从多模态大模型相关概念出发&#xff0c;并以Flamingo 模型为例&#xff0c;探讨了基于多模态大模型训练的演进与前瞻。新一代训练范式包括统一架构、数据工程革新和动态适应机制&#xff0c;以提升跨模态推理能力和长视频理解。 多模态大模型 定义 什么是多模态大模型&…

游戏引擎学习第187天

看起来观众解决了上次的bug 昨天遇到了一个相对困难的bug&#xff0c;可以说它相当棘手。刚开始的时候&#xff0c;没有立刻想到什么合适的解决办法&#xff0c;所以今天得从头开始&#xff0c;逐步验证之前的假设&#xff0c;收集足够的信息&#xff0c;逐一排查可能的原因&a…

HarmonyOS NEXT 关于鸿蒙的一多开发(一次开发,多端部署) 1+8+N

官方定义 定义&#xff1a;一套代码工程&#xff0c;一次开发上架&#xff0c;多端按需部署。 目标&#xff1a;支撑开发者快速高效的开发支持多种终端设备形态的应用&#xff0c;实现对不同设备兼容的同时&#xff0c;提供跨设备的流转、迁移和协同的分布式体验。 什么是18…

当Kafka化身抽水马桶:论组件并发提升与系统可用性的量子纠缠关系

《当Kafka化身抽水马桶&#xff1a;论组件并发提升与系统可用性的量子纠缠关系》 引言&#xff1a;一场OOM引发的血案 某个月黑风高的夜晚&#xff0c;监控系统突然发出刺耳的警报——我们的数据发现流水线集体扑街。事后复盘发现&#xff1a;Kafka集群、Gateway、Discovery服…

Dify+ollama+vanna 实现text2sql 智能数据分析 -01

新鲜出炉-今天安装vanna踩过的坑 今天的任务是安装vanna这个工具&#xff0c;因为dify中自己写的查询向量数据库和执行sql这两步太慢了大概要20S&#xff0c;所以想用下这个工具&#xff0c;看是否会快一点。后面会把这个vanna封装成一个工具让dify调用。 环境说明 我是在本…

uniapp uni-swipe-action滑动内容排版改造

在uniapp开发中 默认的uni-swipe-action滑动组件 按钮里的文字都是横排的 不能换行的 如果是在一些小屏设备 比如PDA这种&#xff0c;同时按钮文字又都是4个字 多按钮的情况 就会发现滑动一下都直接满屏了 观看体验都不好 但默认的官方组件又没有样式的设置&#xff0c;下面就告…

电脑卡怎么办?提升电脑流畅的方法

电脑已经成为我们工作、学习和娱乐不可或缺的伙伴。然而&#xff0c;随着使用时间的增长&#xff0c;许多用户会遇到电脑运行变慢、卡顿的情况&#xff0c;这不仅影响了工作效率&#xff0c;也大大降低了使用体验。本文将为大家分析电脑卡顿的常见原因&#xff0c;并提供一套实…

SpringBoot报错解决方案

org.apache.tomcat.util.http.fileupload.impl.SizeLimitExceededException: the request was rejected because its size (31297934) exceeds the configured maximum (10485760) 文件上传大小超过限制

软件需求未明确非功能性指标(如并发量)的后果

软件需求未明确非功能性指标&#xff08;如并发量&#xff09;可能带来的严重后果包括&#xff1a;系统性能下降、用户体验恶化、稳定性降低、安全风险增加、后期维护成本高企。其中&#xff0c;系统性能下降尤为显著。当软件系统在设计和开发阶段未明确并发量需求时&#xff0…

VScode-i18n-ally-Vue

参考这篇文章&#xff0c;做Vue项目的国际化配置&#xff0c;本篇文章主要解释&#xff0c;下载了i18n之后&#xff0c;该如何对Vscode进行配置 https://juejin.cn/post/7271964525998309428 i18n Ally全局配置项 Vscode中安装i18n Ally插件&#xff0c;并设置其配置项&#…

Spring Boot项目快速创建-开发流程(笔记)

主要流程&#xff1a; 前端发送网络请求->controller->调用service->操纵mapper->操作数据库->对entity数据对象赋值->返回前端 前期准备&#xff1a; maven、mysql下载好 跟学视频&#xff0c;感谢老师&#xff1a; https://www.bilibili.com/video/BV1gm4…

车架号查询车牌号接口如何用Java对接

一、什么是车架号查询车牌号接口&#xff1f; 车架号查询车牌号接口&#xff0c;即传入车架号&#xff0c;返回车牌号、车型编码、初次登记日期信息。车架号又称车辆VIN码&#xff0c;车辆识别码。 二、如何用Java对接该接口&#xff1f; 下面我们以阿里云接口为例&#xff0…

npm : 无法加载文件 C:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本的处理方法

1、安装了node.js后&#xff0c;windows powershell中直接输入npm&#xff0c;然后就报错 2、出现原因&#xff1a;权限不够 系统禁用了脚本的执行&#xff0c;所以我们在windows powershell输入npm -v的时候&#xff0c;就会报上面的错误。 3、解决 Set-ExecutionPolicy Un…

数仓开发那些事(11)

某神州优秀员工&#xff1a;一闪&#xff0c;领导说要给我涨米。 一闪&#xff1a;。。。。&#xff08;着急的团团转&#xff09; 老运维&#xff1a;Oi&#xff0c;两个吊毛&#xff0c;看看你们的hadoop集群&#xff0c;健康度30分&#xff0c;怎么还在抽思谋克&#xff1f…

从零开始完成冒泡排序(0基础)——C语言版

文章目录 前言一、冒泡排序的基本思想二、冒泡排序的执行过程&#xff08;一&#xff09;第一轮排序&#xff08;二&#xff09;第二轮排序&#xff08;三&#xff09;第三轮排序&#xff08;四&#xff09;第四轮排序 三、冒泡排序的代码实现&#xff08;C语言&#xff09;&am…

工业级POE交换机:助力智能化与自动化发展

随着工业互联网、物联网&#xff08;IoT&#xff09;和自动化技术的快速发展&#xff0c;网络设备在工业领域的应用日益广泛。然而&#xff0c;在严苛环境下&#xff0c;传统网络设备往往难以应对复杂的温湿度变化、电磁干扰和供电不稳定等挑战。为同时满足数据传输与供电一体化…

使用ZYNQ芯片和LVGL框架实现用户高刷新UI设计系列教程(第五讲)

在上一讲我们讲解了按键回调函数的自定义函数的用法&#xff0c;这一讲继续讲解回调函数的另一种用法。 首先我们将上一讲做好的按键名称以及自定义回调事件中的按键名称修改&#xff0c;改为默认模式为“open”当点击按键时进入回调函数将按键名称改为“close”&#xff0c;具…

Burp Suite Professional 2024版本安装激活指南

文章目录 burpsuite简介Burp Suite的主要组件&#xff1a;Burp Suite的版本使用场景 下载地址使用教程 burpsuite简介 Burp Suite 是一个广泛使用的网络安全测试工具&#xff0c;特别是在Web应用程序安全领域。它主要用于发现和修复Web应用中的安全漏洞&#xff0c;特别适用于渗…

【c++深入系列】:类与对象详解(上)

&#x1f525; 本文专栏&#xff1a;c &#x1f338;作者主页&#xff1a;努力努力再努力wz &#x1f4aa; 今日博客励志语录&#xff1a; 你仰望的星辰并非遥不可及&#xff0c;而是跋涉者脚印的倒影&#xff1b;你向往的远方未必需要翅膀&#xff0c;只要脚下始终有路&#x…