操作系统 实现请求分页系统中页面置换算法

用C语言实现下列要求,并写出实验报告,报告内容包括:题目、目的、内容和要求、程序清单、运行情况(输入、输出)、总结。设供某进程使用的内存块数为:4页面走向为:432143... 用C语言实现下列要求,并写出实验报告,报告内容包括:题目、
目的、内容和要求、程序清单、运行情况(输入、输出)、总结。
设供某进程使用的内存块数为:4
页面走向为:4 3 2 1 4 3 5 4 3 2 1 5
编程实现 LRU页面置换算法,输出访问过程中物理块中的页号情
况及缺页次数、缺页率。
展开
 我来答
Bwxwle
推荐于2016-08-26 · TA获得超过721个赞
知道小有建树答主
回答量:332
采纳率:0%
帮助的人:314万
展开全部
用链表实现,当页面命中时就把页面提到列表最前面,未命中时把页面插入到列表最前面并移除链表最后一个节点。
#include "stdlib.h"
#include "stdio.h"
#define SEC_NUM 4 // cache size
#define PAGE_NUM 12 // page number

typedef struct Node {
    char page;
    struct Node *next;
} Node;
typedef struct Node *linkList; 

// show current status of cache
void show(Node *cache){
    Node *tmp = cache;
    int i;
    printf("Cache status:");
    for (i = 0; i < SEC_NUM; i++){
        printf("%c", tmp->page);
        tmp = tmp->next;
    }
    printf("\n");
}

// return the pointer of the existing page in cache or NULL if not in cache
Node* isIncluded(Node *head, char page){
    Node *tmp = head, *flag = NULL;
    int i;
    for (i = 0; i < SEC_NUM; i++){
        if(tmp->next->page == page)
            flag = tmp;
        tmp = tmp->next;
    }
    return flag;
}

int main()
{
    int i = 0, index = -1;
    char pages[] = {'4','3','2','1','4','3','5','4','3','2','1','5'}; 
    Node *head, *cache, *tmp, *tmp2;
    int miss_num = 0;
    float miss_ratio = 0;
    // initialize the list
    if ( (head = (linkList)malloc(sizeof(Node))) == NULL){
        printf("Can not allocate memory.");
        return 1;
    }
    head->page = '0';
    head->next = NULL;
    cache = head;

    // assign values to cache
    for (i = 0; i < SEC_NUM; i++){
        if ((tmp = ((linkList)malloc(sizeof(Node)))) == NULL) {
            printf("Can not allocate memory.");
            return 1;
        }
        cache->next = tmp;
        tmp->page = '0';
        tmp->next = NULL;
        cache = tmp;
    }
    show(head->next);
    for (i = 0; i < PAGE_NUM; i++) {
        // the page is already in cache
        // move the page to the first position (right after head)
        if ((tmp = isIncluded(head,pages[i])) != NULL) { 
            tmp2 = head->next;
            head->next = tmp->next; 
            tmp->next = tmp->next->next;  
            head->next->next = tmp2;  
        }
        // the page is not in cache
        // insert the page to the first position, and remove the last node
        else { 
            miss_num ++;
            tmp2 = head->next;
            if ((head->next = (linkList)malloc(sizeof(Node))) == NULL){
                printf("Can not allocate memory.");
                return 1;
            }
            head->next->page = pages[i];
            head->next->next = tmp2; 
            head->next->next->next->next->next = NULL; // assign NULL to the *next of the fourth nod (remove the last node)
        }
        show (head->next);
    }
    miss_ratio = (float)miss_num/PAGE_NUM;
    printf("Number of misses is %d, and miss ratio is %f \n", miss_num, miss_ratio);
    return 0;
}
追问
运行有三个错误
追答
我运行的没问题。你用的什么编译器?把错误贴上来我看看。
feiytk331
2014-06-20 · TA获得超过1232个赞
知道答主
回答量:196
采纳率:100%
帮助的人:149万
展开全部
73682-876-876-377
追问
几个意思?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式