HRRN算法C语言实现
2021/9/18 20:36:30
本文主要是介绍HRRN算法C语言实现,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
刷某客网题,初遇此高响应比优先算法,正在学操作系统任务调度,尝试用C语言写了下,VC环境,验证无误。
综合作业执行时间和作业等待时间,本着“即照顾短作业,又不使长作业等待时间过长”的思想,改进调度性能。
算法思想:
作业完成时间(时刻):作业实际完成的时刻
作业完成时间 = 上一个任务完成时间 + 执行时间
作业周转时间(时间段):作业从提交到执行完毕所需要的时间
周转时间 = 完成时间 - 提交时间
响应比 = 周转时间 / 执行时间
至于响应比为什么要这么算,怎么定义,请大佬告知。
还有剩下所有任务的周转时间和响应比都需要根据当前任务完成而更新。
附上代码:
/* highest response rrtio next */ #include<stdio.h> #include<stdlib.h> #define MAXSIZE 4 /*ERROR MESSAGE*/ #define MERROR_ALLOCATION_ERROR 0 /*TASK_PARAMETER_LOAD_EN*/ #define TASK_PARAMETER_LOAD_EN 0 //RETURN STATUS #define OK 1 #define ERROR 0; typedef int Status; //作业结构体 typedef struct { double subtime; //提交时间 double exetime; //执行时间 double comptime; //完成时间 double turntime; //周转时间 double resrate; //响应比 }Task; //LinkList Node typedef struct LNode { Task task; struct LNode *next; }LNode, *LinkList; //data for initial double subtime[MAXSIZE] = { 8.0, 8.6, 8.8, 9.0 }; double exetime[MAXSIZE] = { 2.0, 0.6, 0.2, 0.5 }; //error message void PrintErrMessage ( int err ) { switch ( err ) { case MERROR_ALLOCATION_ERROR : printf( "MERROR_ALLOCATION_ERROR!\n"); break; default:; } } //Initial Status InitTaskList ( LinkList &L ) { LinkList p,q; L = ( LinkList )malloc( sizeof(LNode) ); //struct head node if ( !L ) { PrintErrMessage( MERROR_ALLOCATION_ERROR ); return ERROR; } L->task.subtime = 0; L->task.exetime = 0; q = L; for ( int i = 0; i<MAXSIZE; ++i ) { p = ( LinkList )malloc( sizeof(LNode) ); //正序构建单链表 p->task.subtime = subtime[i]; p->task.exetime = exetime[i]; p->task.comptime = 0; p->task.turntime = 0; p->task.resrate = 0; q->next = p; q = p; } q->next = NULL; #if TASK_PARAMETER_LOAD_EN > 0 #endif return OK; } //printf void printfTaskLinkList ( LinkList L) { LinkList p = L->next; while( p != NULL ) { printf( "%.2lf %.2lf %.2lf %.2lf %.2lf\n", p->task.subtime, p->task.exetime, p->task.comptime, p->task.turntime, p->task.resrate ); p = p->next; } printf("\n"); } //计算完成时间、周转时间、响应比 void CountTime ( LinkList &L ) { LinkList p,q,j; p = L->next; //compute the complete time and turnround time of the first task. if ( L->task.subtime==0 ) { p->task.comptime = p->task.subtime + p->task.exetime; p->task.turntime = p->task.comptime - p->task.subtime; } //compute the complete time and turnround time of the rest task. q = p->next; do { q->task.comptime = p->task.comptime + q->task.exetime; q->task.turntime = q->task.comptime - q->task.subtime; q->task.resrate = q->task.turntime / q->task.exetime; q = q->next; }while( q != NULL ); //check the largest response time node. q = p->next; j = q->next;easily cause AV error while( j != NULL ) { if ( q->task.resrate > j->task.resrate ) { j = j->next; } else { q = j; j = j->next; } } //move the largest response tine node as the next node to be execute. if ( q != p->next ) { j = p->next; while( j->next != q ) j = j->next; j->next = q->next; q->next = p->next; p->next = q; } //PRINT printfTaskLinkList( L ); //ENTER RECURSION if ( p->next->next->next !=NULL )/if ( p->next != NULL ) cause AV error. CountTime( p ); } void main() { LinkList LTask; InitTaskList( LTask ); printfTaskLinkList( LTask ); CountTime( LTask ); printfTaskLinkList( LTask ); }
动态分配内存之后,利用递归计算,有点绕,因为技术水品有限,参考下就好。不过结果是对的。
结果:以当前任务(第一条任务)计算余下任务响应比并更新
这篇关于HRRN算法C语言实现的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11国产医疗级心电ECG采集处理模块
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南