C语言实现:分页式存储系统位示图管理及多进程内存申请与分配处理
```c #include <stdio.h> #define BLOCKS 64 // 块总数 #define PROCESSES 4 // 进程总数 // 初始化位示图,1表示已占用,0表示未占用 int bitmap[BLOCKS] = {0}; // 已占用的块号 int occupied_blocks[] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19}; int occupied_count = sizeof(occupied_blocks) / sizeof(occupied_blocks[0]); // 标记已占用的块 void mark_occupied() { for (int i = 0; i < occupied_count; i++) { bitmap[occupied_blocks[i]] = 1; } } // 查找空闲块 int find_free_block() { for (int i = 0; i < BLOCKS; i++) { if (bitmap[i] == 0) { bitmap[i] = 1; // 标记为已占用 return i; } } return -1; // 没有空闲块 } // 进程申请内存 int allocate_memory(int process_id, int page_id, int pages_needed) { if (page_id < 0 || page_id >= pages_needed) { return -2; // 页号错误 } int block_number = find_free_block(); if (block_number == -1) { return -1; // 没有空闲块 } return block_number; } int main() { int pages_needed[PROCESSES]; int process_id, page_id; // 读取每个进程申请的内存块数 for (int i = 0; i < PROCESSES; i++) { scanf("%d", &pages_needed[i]); } // 读取进程编号和页号 scanf("%d %d", &process_id, &page_id); // 标记已占用的块 mark_occupied(); // 分配内存 int result = allocate_memory(process_id - 1, page_id, pages_needed[process_id - 1]); if (result == -1) { printf("wait\n"); } else if (result == -2) { printf("error\n"); } else { printf("%d\n", result); } return 0; } ``` 额外需要注意的逻辑点 1. 边界条件检查:确保进程编号和页号在合理范围内,避免数组越界。 2. 位示图更新:每次分配内存后要及时更新位示图,防止重复分配同一块内存。 3. 内存不足处理:当没有足够的空闲块时,正确处理进程等待的情况,确保输出正确的提示信息。 ######[AI写代码神器 | 617点数解答 | 2024-12-02 10:36:44]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)380
- 工程师必备!10 种工程日常易用管理工具大揭秘(百度文心 | 346点数解答 | 2023-11-09 18:26:09)309
- CentOS下Java进程出现futex_wait_queue_me问题的处理全流程(阿里通义 | 283点数解答 | 2023-11-20 14:51:26)487
- 替雷利珠单抗致免疫相关性糖尿病:病例报道与机制探讨,为临床用药敲响警钟( | 164点数解答 | 2024-10-11 14:52:52)289
- Python 代码转 C++:计算花朵鲜艳值总和(字节豆包 | 408点数解答 | 2026-04-19 21:50:57)19
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)350
- iOS开发:手把手教你完整实现代理模式,含声明与实现步骤!(阿里通义 | 268点数解答 | 2023-11-08 00:39:55)276
- JavaScript 开发:用 Animation 实现自定义动画的简易教程 (阿里通义 | 333点数解答 | 2023-11-09 01:50:07)267
- 用 JS 中 for 循环实现 1 到 100 相加并输出结果到页面的完整代码 ( | 240点数解答 | 2024-05-20 22:11:29)497
- 用 JS 的 while 循环实现 1 到 100 相加并输出到页面的代码揭秘( | 47点数解答 | 2024-05-20 22:16:48)386
- Vue.js 与 Matter.js 碰撞:轻松实现物理模拟全攻略 (讯飞星火 | 522点数解答 | 2024-05-29 22:26:06)453
- JS实现移动端网页快捷键创建方式及注意事项(阿里通义 | 284点数解答 | 2024-06-05 19:02:59)284