动态分区分配存储管理方式的内存分配回收_简述采用动态分区分配的内存管理方式时内存回收的流程

最后

小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

开源分享:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】

程序员代码面试指南 IT名企算法与数据结构题目最优解

这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!

image.png

《TCP-IP协议组(第4版)》

本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。

本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。

image.png

Java开发手册(嵩山版)

这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**

image.png

MySQL 8从入门到精通

本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。

image.png

Spring5高级编程(第5版)

本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。

本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。

image.png

JAVA核心知识点+1000道 互联网Java工程师面试题

image.png

image.png

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

image.png

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

在动态分区分配存储管理方式的内存分配中,当有作业请求装入时,根据作业的需要内存空间的大小查询内存各个空闲区,从中找到一个大于或等于该作业大小的内存空闲区,然后按作业需求量划出一个分区装入该作业。作业执行完后,它占用的内存区被收回,称为空闲区,如果该空闲区的相邻分区也是空闲区,就要合并成为一个空闲区。

1.打开“Microsoft Visual C++ 6.0”,输入相关代码,同时在源程序同一目录下新建“input2.txt”,文件内容为:
0,10
10,8
18,10
28,6
34,10
44,9

2.查看内存空闲表;并记录空闲表内容:
在这里插入图片描述
3.为A作业申请7大小的空间;然后查看当前内存空闲表的情况,并记录当前分配情况:
在这里插入图片描述
4.为B作业申请5大小的空间;查看当前内存空闲表的情况,并记录当前分配情况:
在这里插入图片描述

5.申请撤销作业A;查看当前内存空闲表的情况,并记录当前分配情况:
在这里插入图片描述
6.观察上述结果,该程序在内存分配过程中,使用的算法是 首次适应算法 。

7.试将该程序中关于内存分配的算法改为最佳适应算法,给出程序修改位置以及所改代码:

if(frees[j].length<frees[p].length){
				p=j;
			}

	if(frees[i].length>job_length){ 
		if(frees[i].length-job_length<d){
			d=frees[i].length-job_length;
			frees[i].start+=job_length;
			frees[i].length-=job_length;
			occupys[occupy_quantity].length=job_length;
		}
		i++;
	}

执行以下操作:
(1)查看内存空闲表;并记录空闲表内容:
在这里插入图片描述
(2)为A作业申请7大小的空间;查看当前内存空闲表的情况,并记录当前分配情况:
在这里插入图片描述
(3)为B作业申请5大小的空间;查看当前内存空闲表的情况,并记录当前分配情况:
在这里插入图片描述
(4)申请撤销作业A;查看当前内存空闲表的情况,并记录当前分配情况
在这里插入图片描述
8.在回收空闲区时,一共有四种情况,结合程序简单说明。

(1)回收区前邻空闲区。将回收区与前邻空闲区合并,将前邻空闲区大小修改为两者之和。
(2)回收区后邻空闲区。将两区合并,改后邻区始址为回收区始址,大小为两者之和。
(3)回收区前后均邻空闲区。将三个区合并,修改前邻空闲区大小为三者之和。
(4)回收区前后均不邻空闲区。为回收区设置空闲区表项,填入回收区始址和大小并插入空闲区队列。
——————————————————————————————————————————————————————————————————————————————————————
附上源代码(最佳适应算法):

#include"stdio.h"
#include"iostream.h"
#include"string.h"
#include"iomanip.h"
const int MAXJOB=100;   
typedef struct node{
	int start;
	int length;
	char tag[20];
}job;
job frees[MAXJOB];//定义空闲区表
int free_quantity;  
job occupys[MAXJOB];//定义已分配区表
int occupy_quantity;  
void initial(){//初始化函数
	int i;
	for(i=0;i<MAXJOB;i++){
		frees[i].start=-1;
		frees[i].length=0;
		strcpy(frees[i].tag,"free");
		occupys[i].start=-1;
		occupys[i].length=0;
		strcpy(occupys[i].tag,"");
	}
	free_quantity=0;
	occupy_quantity=0;
}
int readData(){
	FILE \*fp;
	char fname[20];
	cout<<"请输入初始空闲表文件名:";
	cin>>fname;   
	if((fp=fopen(fname,"r"))==NULL){
		cout<<"错误,文件打不开,请检查文件名"<<endl;
	}
	else{
		while(!feof(fp)){
			fscanf(fp,"%d,%d",&frees[free_quantity].start,&frees[free_quantity].length);
			free_quantity++;
		}
		return 1;
	}
	return 0;
}
void sort(){
	int i,j,p;
	for(i=0;i<free_quantity-1;i++){
		p=i;
		for(j=i+1;j<free_quantity;j++){
			if(frees[j].length<frees[p].length){
				p=j;
			}
		}
		if(p!=i){
			frees[free_quantity]=frees[i];
			frees[i]=frees[p];
			frees[p]=frees[free_quantity];
		}
	}
}
void view(){
	int i;
	cout<<endl<<"\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_"<<endl;
	cout<<"当前空闲表"<<endl;
	cout<<"起始地址 长度 状态"<<endl;
	for(i=0; i<free_quantity;i++){
		cout.setf(2);
		cout. width(12);
		cout<<frees[i].start;
		cout. width(10);
		cout<<frees[i].length;
		cout. width(8);
		cout<<frees[i].tag<<endl;
	}
	cout<<endl<<"\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_"<<endl;
	cout<<"当前已分配表:"<<endl;
	cout<<"起始地址 长度 占用作业名"<<endl;
	for(i=0; i<occupy_quantity;i++){
		cout.setf(2);
		cout.width(12);
		cout<<occupys[i].start;
		cout.width(10);
		cout<<occupys[i].length;
		cout. width(8);
		cout<<occupys[i].tag<<endl;
	}
}
void best(int th){
	char job_name[20];
	int job_length;
	int i,j, flag,index;
	int d=20;
	cout<<"请输入新申请内存空间的作业名和空间大小:";
	cin>>job_name;
	cin>>job_length; 
	flag=0;
	for(i=0;i<free_quantity;i++){
		if(frees[i].length>=job_length+th){
			flag=1;
			index=i;
			break;
		}	
	}
	if(flag==0) {
	cout<<endl<<"Sorry,当前没有能满足你申请长度的空闲内存,请稍候再试"<<endl;
	}
	else{
	i=index;
	occupys[occupy_quantity].start=frees[i].start;   
	strcpy(occupys[occupy_quantity].tag,job_name);   
	if(frees[i].length>job_length){ 
		if(frees[i].length-job_length<d){


## 最后

分享一套我整理的面试干货,这份文档结合了我多年的面试官经验,站在面试官的角度来告诉你,面试官提的那些问题他最想听到你给他的回答是什么,分享出来帮助那些对前途感到迷茫的朋友。

#### 面试经验技巧篇

* 经验技巧1 如何巧妙地回答面试官的问题
* 经验技巧2 如何回答技术性的问题
* 经验技巧3 如何回答非技术性问题
* 经验技巧4 如何回答快速估算类问题
* 经验技巧5 如何回答算法设计问题
* 经验技巧6 如何回答系统设计题
* 经验技巧7 如何解决求职中的时间冲突问题
* 经验技巧8 如果面试问题曾经遇见过,是否要告知面试官
* 经验技巧9 在被企业拒绝后是否可以再申请
* 经验技巧10 如何应对自己不会回答的问题
* 经验技巧11 如何应对面试官的“激将法”语言
* 经验技巧12 如何处理与面试官持不同观点这个问题
* 经验技巧13 什么是职场暗语

![](https://img-blog.csdnimg.cn/img_convert/784b5f603d0d3a0812336534faabb3ba.webp?x-oss-process=image/format,png)

#### 面试真题篇

* 真题详解1 某知名互联网下载服务提供商软件工程师笔试题
* 真题详解2 某知名社交平台软件工程师笔试题
* 真题详解3 某知名安全软件服务提供商软件工程师笔试题
* 真题详解4 某知名互联网金融企业软件工程师笔试题
* 真题详解5 某知名搜索引擎提供商软件工程师笔试题
* 真题详解6 某初创公司软件工程师笔试题
* 真题详解7 某知名游戏软件开发公司软件工程师笔试题
* 真题详解8 某知名电子商务公司软件工程师笔试题
* 真题详解9 某顶级生活消费类网站软件工程师笔试题
* 真题详解10 某知名门户网站软件工程师笔试题
* 真题详解11 某知名互联网金融企业软件工程师笔试题
* 真题详解12 国内某知名网络设备提供商软件工程师笔试题
* 真题详解13 国内某顶级手机制造商软件工程师笔试题
* 真题详解14 某顶级大数据综合服务提供商软件工程师笔试题
* 真题详解15 某著名社交类上市公司软件工程师笔试题
* 真题详解16 某知名互联网公司软件工程师笔试题
* 真题详解17 某知名网络安全公司校园招聘技术类笔试题
* 真题详解18 某知名互联网游戏公司校园招聘运维开发岗笔试题

![](https://img-blog.csdnimg.cn/img_convert/4e8d4f4214357bb5ec5ca889b7bf3c78.webp?x-oss-process=image/format,png)

资料整理不易,点个关注再走吧

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

园招聘运维开发岗笔试题

[外链图片转存中...(img-dHQB26GF-1715505323635)]

资料整理不易,点个关注再走吧

> **本文已被[CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)收录**

**[需要这份系统化的资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**

  • 18
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值