最佳適應算法模擬內存分配

最佳適應算法

從全部空閑區中找出能滿足作業要求的,且大小最小的空閑分區,這種方法能使碎片盡量小。

問題描述

  • Given five memory partitions of 100 KB, 500 KB, 200 KB, 300 KB, and 600 KB (in order), how would each of the first-fit, best-fit, and worst-fit algorithms place processes of 212 KB, 417 KB, 112 KB, and 426 KB (in order)? Which algorithm makes the most efficient use of memory?

問題解決

  • 為212k分配空間:

    找到第一個跟212k大小最接近的空閑區找到第四個空閑區300>212k,剩余88k空閑區
    
  • 為417k分配空間:

    找到第一個跟417k大小最接近的空閑區找到第二個空閑區500>417,剩余83k空閑區
    
  • 為112k分配空間:

    找到第一個跟112k大小最接近的空閑區找到第三個空閑區200>112k,剩余88k空閑區
    
  • 為426k分配空間:

    找到第一個跟426大小最接近的空閑區找到第五個空閑區600k>426,剩余74k空閑區
    

code

#include<stdio.h>
#include<stdlib.h>#define N 5
#define M 5int buf[N]={100,500,200,300,600};
int need_dis[M]={212,417,112,426,200};
typedef struct LNode *List;struct LNode{int order;int buffer;LNode *next;
};List list_init(){List head,p,m;int i;for(i=0;i<N;i++){if(i==0){m=(LNode*)malloc(sizeof(struct LNode));if(!m){printf("Error:memory!\n");exit(0);}m->order=i;m->buffer=buf[i];m->next=NULL;head=p=m;}else{m=(LNode*)malloc(sizeof(struct LNode));if(!m){printf("Error:memory wrong\n");exit(0);}m->order=i;m->buffer=buf[i];m->next=NULL;p->next=m;p=p->next;}}return head;
}void best_fit(List head){int i,j,k;int min;int order;List p;for(i=0;i<M;i++){min=-1;order=-1;p=head;while(p){if(p->buffer>=need_dis[i]){if(min<0){min=p->buffer-need_dis[i];order=p->order;}else{if(min>p->buffer-need_dis[i]){min=p->buffer-need_dis[i];order=p->order;}}}p=p->next;} if(order==-1){printf("\n");printf("分配完成%d個\n",i);printf("第%d個進程失敗\n",i+1);printf("\n");break; }else{p=head;while(p){if(p->order==order)p->buffer-=need_dis[i];p=p->next;}}}
}void print(List p){while(p){printf("%d:%d\n",p->order,p->buffer);p=p->next;}
}int main(){List p;p=list_init();printf("分配內存前\n"); print(p);best_fit(p);printf("分配內存后\n");print(p);return 0;
} 

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/375923.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/375923.shtml
英文地址,請注明出處:http://en.pswp.cn/news/375923.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

單片機c語言 i%3c%3c1,單片機C語言作業及上機習題及答案

《單片機C語言作業及上機習題及答案》由會員分享&#xff0c;可在線閱讀&#xff0c;更多相關《單片機C語言作業及上機習題及答案(37頁珍藏版)》請在人人文庫網上搜索。1、第一次課熟悉winTC編譯環境、熟悉C語言程序結構1.使用C 語言編譯環境&#xff0c;輸入下面的源程序。將你…

基于順序搜索的動態分區分配算法模擬內存動態分配--最佳適應算法(best fit,BF)

BF算法、男朋友算法&#xff0c;哈哈 要實現動態分區分配&#xff0c;需要考慮三個方面的問題。分別是數據結構、分區分配算法、分區的分配與回收操作。 首數據結構 這里我們使用的是空閑分區鏈&#xff0c;采用雙向鏈表表示空閑分區。 具體實現如下&#xff1a; typedef …

我也要談談大型網站架構之系列(4)——分布式中的異步通信

我們知道在面向對象編程中&#xff0c;總會想著各種辦法來實現代碼的解耦&#xff0c;從而讓項目中的各種人員面對自己熟悉的業務進行開發&#xff0c; 做到術業有專攻&#xff0c;比如大家非常熟悉的三層架構&#xff0c;MVC&#xff0c;MVP以及MVVM模式&#xff0c;讓前端設計…

node模塊函數圖解

已截圖方式記錄模塊信息&#xff1a; HTTP模塊&#xff1a; 對于網絡返回處理狀態封裝了很多種&#xff0c;我已截圖展現 以上狀態也是在http協議中包含的狀態。 http函數&#xff1a; path模塊&#xff1a; 轉載于:https://www.cnblogs.com/kuailingmin/p/4547538.html

android 心跳效果動畫,Android實現心跳的效果

最近再做一個教育類的項目。在做一些學習工具的時候&#xff0c;美工提出了一些要求&#xff0c;大致如下&#xff1a;其實實現過程也不難&#xff0c;大致就是對一個視圖控件添加一個圓形的背景&#xff0c;然后該視圖進行動畫處理&#xff0c;膨脹的同時&#xff0c;透明度增…

Oracle超出最大連接數問題及解決

用過Oracle的應該都熟悉如何查看和設置Oracle數據庫的最大連接數。這里就再啰嗦一遍。 查看當前的連接數&#xff0c;可以用select count(*) from v$process;設置的最大連接數&#xff08;默認值為150&#xff09;select value from v$parameter where name ‘processes’;修改…

操作系統上機作業--使用系統調用實現mycat

mycat.c的功能與系統cat程序相同mycat將指定的文件內容輸出到屏幕&#xff0c;例子如下&#xff1a;要求使用系統調用open/read/write/close實現 $ cat /etc/passwd root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin bin:x:2:2:bin:/bin:/u…

GCDAynscSocket簡單使用-客戶端

這是一篇介紹GCDAynscSocket客戶端簡單使用的文章&#xff08;服務端后續添加&#xff09; 背景&#xff1a;在這篇文章之前我對socket的了解僅限于知道有TCP、UDP兩種方式&#xff0c;使用抓包工具時甚至看不懂抓包數據&#xff08;慚愧...&#xff09;&#xff0c;所以本文介…

微信android版字體,微信炫彩字下載-微信七彩字體 安卓版v1.6.2-PC6安卓網

微信七彩字體一款方便的手機字體更換軟件&#xff0c;微信炫彩字軟件集合了上百款優質中文美化字體&#xff0c;微信七彩發光字里有可愛的喵嗚體、卡通體&#xff0c;清秀的靜蕾體等多種字體。軟件介紹微信、qq上最好用、最個性的聊天字體應用&#xff0c;讓你的聊天與眾不同&a…

Android SQLite 數據庫 增刪改查操作

Android SQLite 數據庫 增刪改查操作 轉載▼一、使用嵌入式關系型SQLite數據庫存儲數據在Android平臺上&#xff0c;集成了一個嵌入式關系型數據庫——SQLite&#xff0c;SQLite3支持NULL、INTEGER、REAL&#xff08;浮點數字&#xff09;、TEXT(字符串文本)和BLOB(二進制對象…

SIT與UAT的分別

在企業級軟件的測試過程中&#xff0c;經常會劃分為三個階段——單元測試&#xff0c;SIT和UAT&#xff0c;如果開發人員足夠&#xff0c;通常還會在SIT之前引入代碼審查機制&#xff08;Code Review&#xff09;來保證軟件符合客戶需求且流程正確。下面簡單介紹一下SIT和UAT的…

操作系統上機作業--使用系統調用實現mycp

mycp.c的功能與系統cp程序相同將源文件復制到目標文件&#xff0c;例子如下&#xff1a;要求使用系統調用open/read/write/close實現 $ cat /etc/passwd root:x:0:0:root:/root:/bin/bash daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin bin:x:2:2:bin:/bin:/usr/sbin/nolo…

android自動化持續集成,基于持續集成的Android自動化測試.pdf

基于持續集成的Android自動化測試.pdf2015 年 第24 卷 第 5 期 計 算 機 系 統 應 用①基于持續集成的Android 自動化測試王 焱, 張 征(華中科技大學 自動化學院, 武漢 430074)摘 要: Android 測試方面的研究大多集中在測試工具和框架的實現上, 有些工具和框架可以實現測試用例…

Csharp 高級編程 C7.1.2

第七章 代理&#xff08;1&#xff09; 一、代理要聲明 二、代理使用步驟 聲明代理初始化代理&#xff08;使用 實例的方法名 作為參數&#xff09;使用代理代碼示例&#xff1a; /*C7.1.2*/ using System; using System.Collections.Generic; using System.Linq; using System…

操作系統上機作業--實現mysys(多進程)

mysys.c: 實現函數mysys&#xff0c;用于執行一個系統命令&#xff0c;要求如下mysys的功能與系統函數system相同&#xff0c;要求用進程管理相關系統調用自己實現一遍使用fork/exec/wait系統調用實現mysys不能通過調用系統函數system實現mysys 測試程序 #include <stdio.…

06鏈隊列_LinkQueue--(棧與隊列)

#include "stdio.h" #include "stdlib.h" #include "io.h" #include "math.h" #include "time.h"#define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 #define MAXSIZE 20 /* 存儲空間初始分配量 */ty…

android 透明變成白色,android – 狀態欄不透明但是白色

為了用anko DSL測試kotlin我決定在最后一個android studio ide(2.1.3)中使用kotlin插件(1.0.3)和最新的anko庫(0.9)開始一個新的proyect我使用默認的proyect Navigation Drawer Activity,所以我只需要將主xml轉換為anko.這是xml&#xff1a;xmlns:android"http://schemas.…

操作系統上機作業--實現shell(1)(多進程)

sh1.c: 實現shell程序&#xff0c;要求具備如下功能支持命令參數 $ echo arg1 arg2 arg3 $ ls /bin /usr/bin /home 實現內置命令cd、pwd、exit $ cd /bin $ pwd /bin 實現思路&#xff1a;在獲取命令字符串后&#xff0c;用strtok函數對字符串進行處理&#xff0c;獲取參數…

VC下勉強可用的list

linux內核中的list太好用了&#xff0c;可惜VC編譯器不支持 typeof 關鍵字&#xff0c;將linux內核中的list直接移植過來不能用 修改所有與typeof相關的代碼后&#xff0c;終于可以勉強在VC下運行起來了&#xff0c;但是還不完美&#xff0c;list_for_each_entry和list_for_eac…

當執行游戲0xc000007b錯誤的解決方法

如圖&#xff0c;這個錯誤使無數玩家煩惱。 出現這個錯誤&#xff0c;可能是硬件的問題&#xff0c;也可能是軟件的問題。可是&#xff0c;因為硬件引起該問題的概率非常小&#xff0c;而且除了更換硬件之外沒有更好的解決方法&#xff0c;因此本文將具體介紹怎樣通過軟件解決此…