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

公司要招个做网站的人seo泛目录培训

公司要招个做网站的人,seo泛目录培训,专业的集团网站开发,泉州网站建设服务背景 在之前我们提到采用自定义的内存分配器来解决防止频繁 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.tj-hxxt.cn/news/122729.html

相关文章:

  • 网站建设 厦门seo搜索优化技术
  • 手工做皮具国外的网站成都百度提升优化
  • 前端开发遇到的问题及解决方法宁波seo外包公司
  • 机械设备网站建设厦门百度公司
  • photoshop怎么做网站草图什么是seo优化
  • 全免费源码网seo监控系统
  • 武汉医院网站建设搜索排名怎么做
  • 福州网站制作有限公司国内最大的搜索引擎
  • 网站开发论坛样式搜索引擎培训班
  • 湖北省和住房建设厅官方网站独立站seo外链平台
  • 公司域名申请流程seo网络推广专员招聘
  • 做网站每年要交不费用吗百度小说风云榜排名
  • 做网站时怎么让边框细一点百度网盘客服人工电话
  • wordpress与cms哪个好用seo优化托管
  • wordpress网站怎么加小游戏西安网约车
  • 广告平面设计要学多久seo关键词推广案例
  • 网站模块 带采集网站建设方案开发
  • 合肥网站设计高端公司网站服务器ip查询
  • 使用word做网站谷歌搜索引擎下载
  • 网络技术服务360优化大师下载安装
  • 甘肃省人民政府领导免费seo快速排名系统
  • 做网站公司需要准备资料sem搜索引擎
  • 什么网站做调查能赚钱吗指数分布的期望和方差
  • 美女手机网站源码如何注册自己的网站
  • 广州电商网站开发软文300字介绍商品
  • 网站 后台百度推广开户费用多少
  • java做网站需要什么泰州百度seo
  • 中国采招网长沙seo关键词
  • wordpress 安全 插件下载seo基本概念
  • 校园兼职信息发布网站开发论文国外独立网站如何建站