当前位置: 首页 > news >正文

公司网站制作的费用申请怎样网站seo

公司网站制作的费用申请,怎样网站seo,3d全景网站怎么做,梦幻西游网页版下载背景 在之前我们提到采用自定义的内存分配器来解决防止频繁 make 导致的 gc 问题。gc 问题本质上是 CPU 消耗,而内存分配器本身如果产生了大量的 CPU 消耗那就得不偿失。经过测试初代内存分配器实现过于简单,产生了很多 CPU 消耗,因此必须优…

背景

在之前我们提到采用自定义的内存分配器来解决防止频繁 make 导致的 gc 问题。gc 问题本质上是 CPU 消耗,而内存分配器本身如果产生了大量的 CPU 消耗那就得不偿失。经过测试初代内存分配器实现过于简单,产生了很多 CPU 消耗,因此必须优化内存分配器的性能。

性能消耗原因

在内存的分配和回收上,使用了简单的循环检测,当内存碎片较多的时候,循环消耗非常可观

查找可分配的内存

在这里插入图片描述

找到回收的内存偏移

在这里插入图片描述

性能优化

很快在社区中大家给出了一个称为 Buddy 的内存分片算法,那么这个算法是否能解决问题呢?

Buddy 算法

这是一个非常高效的算法,采用的是满二叉树数据结构,用一个数组来表示,然而当实际使用时却遇到了问题,因为我需要在自研的 BufReader 中使用,因此不能出现内存缝隙。Buffdy 算法在回收内存时只能按照申请什么回收什么的原则。举例,我申请了一个var a []byte = alloc(100),那么回收必须也是回收 free(a)。而自研的 BufReader,需要“部分回收”能力。比如先回收a[50:],然后再回收a[:50]。那么 Buddy 算法将无能为力。
在这里插入图片描述

当然,这个算法最终还会用到,这里先留个悬念。

双圣树模型

这是我自己起的名字,实际上是利用两颗平衡二叉树来实现快速找到可分配的内存以及快速回收内存。

type	Allocator struct {pool       []*BlocksizeTree   *BlockoffsetTree *BlockSize       int// history    []History}

分配树

这颗树,用来快速查找可分配的内存,我们将可分配的内存用一个节点表示

type	Block struct {Start, End inttrees      [2]Tree}

sizeTree 通过对每个节点的大小(End-Start)进行排序,在分配时,通过查找树中刚好大于等于待分配大小的节点,再修改这个节点,对树进行平衡即可。

回收树

这颗树,用来找到回收内存块前后的 Block,通过合并或者插入 Block 达到回收内存的效果。

合并前面合并后面合并前后仅插入
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

共享节点

由于两棵树只是表达了不同的排序,里面所有节点的数量和属性都是相同的,因此不需要两套节点,只需要公用一套节点集合即可。

type Tree struct {left, right *Blockheight      int}

每个节点有两套指针,分别指向两棵树的不同的子节点,从而在逻辑上形成了两棵树。

进阶优化

虽然我们最终通过双圣树模型,实现了内存分配器的性能优化,但是优化并没有因此而停止。因为上述的内存分配器是无锁的,只适合给单个 goroutine 使用,如果加锁则性能大打折扣。
那么从宏观角度来说,分配器持有的大内存块也会存在需要回收的情况。比如在流销毁的时候。

再次使用 Buddy 算法

这时候大内存块就不需要部分回收了,此时就又可以采用 Buddy 算法了。我们只需要在申请大内存块时,按照 2 倍数来申请,可以最大化利用。最终我们形成了两级内存分配。当然在这里就需要用锁了。
在这里插入图片描述

http://www.yayakq.cn/news/850223/

相关文章:

  • 雨颜色网站建设工业和信息化部反诈中心发短信
  • 男女直接做视频教学视频网站学校网站建设项目要多少钱
  • 一个主机建多少个网站天津哪家网站做的好
  • 保险行业网站模板基于5G的网站设计
  • 龙岗网站设计信息网络推广 公司 200个网站
  • 想自学做网站做网站是用什么软件做的
  • 科技小手工正规网站优化公司
  • 网站建设头部代码沈阳网站建设 龙兴科技
  • 高级网站开发工程师证书重庆专业网站推广方案
  • 怎样用mysql做网站建自己的零售网站
  • 军事信息化建设网站wordpress 开发文档
  • 怎么查找网站wordpress小工具调用
  • 微网站价格表wordpress 精致博客
  • 石家庄网站建站服装类的网站建设
  • 奥联网络网站建设网站建设 m.ykn.cc
  • 做高清图的网站玉溪建设网站
  • 网站建设初级教程python wordpress采集器
  • 做网站需要准备哪些7牛wordpress
  • 拓和科技有限公司网站个人域名注册流程
  • 南宁建站模板展示无锡网站建设818gx
  • 建设银行E路航如何自动进入网站1.86神华网站两学一做
  • 渭南网站建设网站建设南京百度快照优化排名
  • 江门市建设工程备案网站58同城最新消息招聘
  • 宝格丽网站建设策划案投票链接制作
  • 电子商务等于做网站吗网站访问速度分析
  • 公司内部网站怎么做在360做网站和百度做网站的区别
  • 建网站怎么备案浅笑云虚拟主机
  • 网站模块图未来网站发展方向
  • 开个做网站要多少钱wordpress静态化nginx
  • 黄村网站建设互网站开发维护成本高