MIB 6.1810实验Xv6 and Unix utilities(4)primes

news2025/1/27 13:33:01

难度: hard/moderate

Write a concurrent prime sieve program for xv6 using pipes and the design illustrated in the picture halfway down this page and the surrounding text. This idea is due to Doug McIlroy, inventor of Unix pipes. Your solution should be in the file user/primes.c.

user/primes.c 文件中,利用管道和进程间通信的机制实现一个基于质数筛法(埃拉托斯特尼筛法)的程序。

Your goal is to use pipe and fork to set up the pipeline. The first process feeds the numbers 2 through 35 into the pipeline. For each prime number, you will arrange to create one process that reads from its left neighbor over a pipe and writes to its right neighbor over another pipe. Since xv6 has limited number of file descriptors and processes, the first process can stop at 35.

补充:

埃拉托斯特尼筛法(Sieve of Eratosthenes)是一种用于寻找一定范围内所有质数的简单且高效的算法。这个算法的基本思想是从小到大逐个筛去合数,最终剩下的就是质数。

算法步骤如下:

  1. 首先,创建一个包含从2到某个给定最大数的所有整数的列表。
  2. 从第一个素数2开始,将其所有的倍数(除了2本身)标记为合数(非质数)。
  3. 然后,选择下一个未标记的数,即下一个未被排除的素数,重复步骤2,直到没有未标记的数为止。

这个算法的主要思路在于利用倍数的概念,通过不断地排除合数,最终得到剩下的就是质数。

例如,假设我们要找出小于等于 30 的所有质数:

  • 首先,我们列出 2 到 30 的所有数。
  • 从 2 开始,我们标记 2 的所有倍数(除了2本身),即4、6、8、10、12、14、16、18、20、22、24、26、28 和 30。
  • 接下来,我们选择下一个未标记的数 3,然后标记 3 的所有倍数(除了3本身),即6、9、12、15、18、21、24、27 和 30。
  • 然后继续这个过程,选择下一个未标记的数 5,然后标记 5 的所有倍数(除了5本身),即10、15、20、25 和 30。
  • 最后,选择下一个未标记的数 7,然后标记 7 的所有倍数(除了7本身),即14和28。

最终剩下的未被标记的数就是质数:2、3、5、7、11、13、17、19、23和29。

思路:第一个子进程输入2~35。所有的子进程都是从父进程读取数据,然后将读到的一个数据打印出来,将所有读到的不是它倍数 的数据传递给自己的子进程。

 

#include "kernel/types.h"
#include "kernel/stat.h"
#include "user/user.h"

#define READ 0
#define WRITE 1

void function(int num[],int size){
    if(size==0)return;
    int p[2];
    pipe(p);
    int pid=fork();
    if(pid>0){
        close(p[READ]);
        for(int i=0;i<size;i++){
            write(p[WRITE],&num[i],sizeof(num[i]));
        }
        close(p[WRITE]);
        wait(0);
    }else{
        close(p[WRITE]);
        int numc[34];
        int index=0;
        int tmp,min;
        while(read(p[READ],&tmp,sizeof(tmp))){
            if(index==0){
                min=tmp;
                printf("prime %d\n",min);
                index++;
            }
            if(tmp%min!=0){
                numc[index-1]=tmp;
                index++;
            }
        }
        close(p[READ]);
        function(numc,index-1);
        exit(0);
    }
}

int main(int argc, char *argv[])
{
    int num[34];
    int index = 0;
    for(int i=2;i<=35;i++){
        num[index++]=i;
    }
    function(num,34);
    return 0;
}

参考:

MIT6.S081操作系统实验2021(xv6系统)——lab1 Xv6 and Unix utilities_mit操作系统实验_拉依达不拉胯的博客-CSDN博客

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

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

相关文章

麦克纳姆轮x运动学分析

麦克纳姆轮介绍 A轮 B轮 我们以俯视图的中心为坐标系原点 A轮轴向方向过2 4象限 B轮轴向方向过1 3象限 这里相当于从下往上看仰视图相当于B轮的俯视图 辊子转动方向是不会产生给机器人运动的力,轴向方向会产生运动的摩擦力。 车如果向前运动则A轮要产生45斜向上的力 车如果向…

漂亮的bootstrap后台模板

优雅典型的Bootstrap后台模板 在现今数字化时代&#xff0c;拥有一个漂亮且易于使用的后台模板对于网站或应用程序的成功至关重要 Bootstrap后台模板为您提供了一种简单而强大的方式来构建出色的管理界面&#xff0c;为用户带来无缝的操作体验 我们的Bootstrap后台模板不仅具…

微信小程序 限制字数文本域框组件封装

微信小程序 限制字数文本域框 介绍&#xff1a;展示类组件 导入 在app.json或index.json中引入组件 "usingComponents": {"text-field":"/pages/components/text-field/index"}代码使用 <text-field maxlength"500" bindtabsIt…

复杂数据统计与R语言程序设计实验二

1、创建一个对象&#xff0c;并进行数据类型的转换、判别等操作&#xff0c;步骤如下。 ①使用命令清空工作空间&#xff0c;创建一个对象x&#xff0c;内含元素为序列&#xff1a;1&#xff0c;3&#xff0c;5&#xff0c;6&#xff0c;8。 ②判断对象x是否为数值型数据。 ③…

Elasticsearch基础条件查询

条件查询 query&#xff1a;查询 match&#xff1a;匹配 match_all&#xff1a;匹配所有 #第一种 GET /shopping/_search?q名字:张三#第二种 GET /shopping/_search {"query": {"match": {"名字": "张三"}} }#全量查询 match_all G…

Pandas 将DataFrame中单元格内的字典dict拆分成单独的列

核心是应用 pd.Series&#xff0c; 具体操作如下&#xff1a; import pandas as pddata {years: [2025],week: [{f"week_{i}": i for i in range(3)}]} df pd.DataFrame(data) print(df)df pd.concat([df, df[week].apply(pd.Series)], axis1).drop(week, axis1)…

12V升压18V 1A 内置MOS 升压芯片5-35V输入内置MOS升压IC

12V升压18V 1A 内置MOS 升压芯片5-35V输入内置MOS升压IC

RF 检测器/控制器MS2351M

产品简述 MS2351M 是一款对数放大器芯片&#xff0c;主要用于接收信号强度 指示 RSSI 与功率放大器控制&#xff0c;工作频率范围是 50M  3000MHz &#xff0c; 因频率与温度不同&#xff0c;动态范围达 35dB 到 45dB 。 MS2351M 是电压响应器件&#xff0c; 50M…

抖音内容创作五大方向,让你轻松吸引观众

适合在抖音上探索的五个方向&#xff0c;每个方向都有相关的账号案例&#xff0c;下面来具体看一下&#xff1a;1. 以自己的工作为灵感 利用自己的工作经验&#xff0c;分享与你的工作相关的内容。比如&#xff0c;如果你是房产中介&#xff0c;可以分享购房知识;如果你是汽车销…

centos7 网卡聚合bond0模式配置

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、什么是网卡bond二、网卡bond的模式三、配置bond0 一、什么是网卡bond 所谓bond&#xff0c;就是把多个物理网卡绑定成一个逻辑上的网卡&#xff0c;使用同一个…

Flume学习笔记(2)—— Flume进阶

Flume进阶 Flume 事务 事务处理流程如下&#xff1a; Put doPut&#xff1a;将批数据先写入临时缓冲区putListdoCommit&#xff1a;检查channel内存队列是否足够合并。doRollback&#xff1a;channel内存队列空间不足&#xff0c;回滚数据 Take doTake&#xff1a;将数据取…

zookeeper学习记录

本文Java代码地址&#xff1a; https://gitee.com/blackjie_1/ljUp/tree/master/zookeeperDemo 个人博客网站&#xff1a;什么是快乐 基于docker 安装 拉取zookeeper 3.4.10 docker pull zookeeper:3.4.10启动服务端 docker run -d -p 2181:2181 -v /root/docker/zookeepe…

电源地虚接,导致信号线发烫

音频板的信号是经过隔直电容接到音频板的。

【Linux】C文件系统详解(一)——C文件操作

文章目录 文件操作总结预备知识结论: C文件操作回顾语言方案w写入方式a写入方式r只读方式 系统方案但是这个**没有设置权限**,需要这样改: 文件操作总结 1.文件描述符,重定向,缓冲区,语言和系统关于文件的不同的视角的理解 – 都是要让我们深刻理解文件 2.文件系统 3.动静态库 …

实时音视频方案汇总

若有好的方案欢迎留言讨论&#xff0c;非常感谢&#xff0c;汇总了一些&#xff0c;从市面上了解的一些低时延的端到端的方案&#xff0c;仅供参照&#xff0c;若有问题&#xff0c;也欢迎留言更正&#xff01; 方案 方案描述 时延 备注 1大华同轴高清电缆200米电缆&#xf…

Python 使用difflib库 快速实现批量对比文件差异

关注我们 本文内容仅供学习参考,不足错误之处,还请多多指正,如果喜欢我们,请关注我们,你的支持就是我们最大的动力。 需求来源 霍克是一名软件实施工程师,每次版本升级时,虽然会提供升级相关的清单,但不会详细说明具体的改动点。为了能够更有针对性地验证和测试系统,…

通过 Canal 将 MySQL 数据实时同步到 Easysearch

Canal 是阿里巴巴集团提供的一个开源产品&#xff0c;能够通过解析数据库的增量日志&#xff0c;提供增量数据的订阅和消费功能。使用 Canal 模拟成 MySQL 的 Slave&#xff0c;实时接收 MySQL 的增量数据 binlog&#xff0c;然后通过 RESTful API 将数据写入到 Easysearch 中。…

Spring Boot Actuator:自定义端点

要在Spring Boot Actuator中实现自定义端点&#xff0c;可以按照以下步骤进行操作&#xff1a; 1.创建一个自定义端点类 该类需要使用Endpoint注解进行标记&#xff0c;并使用Component注解将其作为Spring Bean进行管理。 package com.example.highactuator.point;import lo…

Linux项目自动化构建工具:make与Makefile的基本用法

目录 1.什么是makefile 2.快速简单了解make/Makefile的使用 3.背后的知识&#xff1a; 4.依赖关系 5.其他写法 1.什么是makefile 会不会写makefile&#xff0c;从一个侧面说明了一个人是否具备完成大型工程的能力一个工程中的源文件不计数&#xff0c;其按类型、功能、模块…

phpStorm Xdebug调试 加FireFox浏览器

步骤1&#xff1a; [Xdebug] zend_extension“D:\phpstudy_pro\Extensions\php\php5.4.45nts\ext\php_xdebug.dll” xdebug.collect_params1 xdebug.collect_return1 xdebug.remote_enableOn xdebug.remote_hostlocalhost xdebug.remote_port9001 xdebug.remote_handlerdbgp ;…