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

眉山网站优化做手机网站尺寸大小

眉山网站优化,做手机网站尺寸大小,网站怎样查是哪家做的,免费建网站哪个平台好一#xff1a;背景1. 讲故事在前一篇大内存排查中#xff0c;我们看到了Dictionary正在做扩容操作#xff0c;当时这个字典的count251w#xff0c;你把字典玩的66飞起#xff0c;其实都是底层为你负重前行#xff0c;比如其中的扩容机制#xff0c;当你遇到几百万甚至千… 一背景1. 讲故事在前一篇大内存排查中我们看到了Dictionary正在做扩容操作当时这个字典的count251w你把字典玩的66飞起其实都是底层为你负重前行比如其中的扩容机制当你遇到几百万甚至千万的大集合这个扩容机制还真的需要挖一下免的入戏太深难以自拔。为了方便讲述我准备从List说起因为它最简单哈????????????二List扩容机制1. 如何查看要想看它的扩容机制可以用ILSpy去看看List的源码即可非常简单。从源码的 int num (_items.Length 0) ? 4 : (_items.Length * 2) 可以非常清楚的看到4个空间起步后面都是 *2 的扩容也就说当你有 2^(n-1) 1 个元素实际上你需要占用 2^n个空间。下面我用C#代码演示一下static void Main(string[] args){var list1 Enumerable.Range(0, (int)Math.Pow(2, 22)).ToList();var list2 new Listint(list1);list2.Add(1);Console.WriteLine($list1.Capacity{list1.Capacity});Console.WriteLine($list2.Capacity{list2.Capacity});Console.ReadLine();}------ output -------list1.Capacity4194304 list2.Capacity8388608 从代码中可以看到当List中已有 4194304个元素的时候再往其中塞入一个元素仅仅是多一个在底层可是翻倍的空间占用哦太可气了要想往深处看可以用windbg看一下各自数组占用大小。 0:000 !DumpObj /d 000001ec037d2e20 Name: System.Collections.Generic.List1[[System.Int32, mscorlib]] Fields:MT Field Offset Type VT Attr Value Name 00007ffde2ac8538 400189e 8 System.Int32[] 0 instance 000001ec147b9c10 _items 00007ffde2ac85a0 400189f 18 System.Int32 1 instance 4194304 _size 00007ffde2ac85a0 40018a0 1c System.Int32 1 instance 4194304 _version 00007ffde2ac5dd8 40018a1 10 System.Object 0 instance 0000000000000000 _syncRoot 00007ffde2ac8538 40018a2 0 System.Int32[] 0 shared static _emptyArray Domain:Value dynamic statics NYI 000001ec01bc0920:NotInit 0:000 !do 000001ec147b9c10 Name: System.Int32[] MethodTable: 00007ffde2ac8538 EEClass: 00007ffde2c35918 Size: 16777240(0x1000018) bytes Array: Rank 1, Number of elements 4194304, Type Int32 (Print Array)Fields:None0:000 !do 000001ec037d2e78Name: System.Collections.Generic.List1[[System.Int32, mscorlib]]MethodTable: 00007ffde2ada068EEClass: 00007ffde2c3b008Size: 40(0x28) bytesFile: C:\WINDOWS\Microsoft.Net\assembly\GAC_64\mscorlib\v4.0_4.0.0.0__b77a5c561934e089\mscorlib.dllFields:MT Field Offset Type VT Attr Value Name00007ffde2ac8538 400189e 8 System.Int32[] 0 instance 000001ec167b9c80 _items00007ffde2ac85a0 400189f 18 System.Int32 1 instance 4194305 _size00007ffde2ac85a0 40018a0 1c System.Int32 1 instance 1 _version00007ffde2ac5dd8 40018a1 10 System.Object 0 instance 0000000000000000 _syncRoot00007ffde2ac8538 40018a2 0 System.Int32[] 0 shared static _emptyArray Domain:Value dynamic statics NYI 000001ec01bc0920:NotInit 0:000 !do 000001ec167b9c80Name: System.Int32[]MethodTable: 00007ffde2ac8538EEClass: 00007ffde2c35918Size: 33554456(0x2000018) bytesArray: Rank 1, Number of elements 8388608, Type Int32 (Print Array)Fields:None可以清楚的看到,一个int[] 占用 16777240 byte /1024/1024 16M一个 int[] 占用 33554456 byte/1024/1024 32M,可这是翻倍的空间哈。2. 真的以为是仅仅翻了一倍吗为什么我要这么说呢仔细看看Capacity的Set实现如下代码 public int Capacity {get{ return _items.Length; }set{if (value 0){T[] array new T[value];if (_size 0){Array.Copy(_items, 0, array, 0, _size);}_items array;}} } 大家仔细研读这个流程是先定义好新size的数组array然后将老的数组(_items) copy到 新数组array中然后将array的引用给了老的数组,不难看出真正的Size应该是 array(32M) _items16M 48M 才是真正的大小只要GC没有回收老的_items(16M)那就一直保持48M的大小你说呢要怎么验证呢? 大家可以用windbg去看看托管堆中 int[] 不就可以啦。 var list1 Enumerable.Range(0, (int)Math.Pow(2, 22)).ToList(); list1.Add(1);0:000 !DumpHeap -mt 00007ffde2ac8538 -min 102400Address MT Size 0000024c103e9ba0 00007ffde2ac8538 4194328 0000024c107e9bd8 00007ffde2ac8538 8388632 0000024c10fe9c10 00007ffde2ac8538 16777240 0000024c11fe9c48 00007ffde2ac8538 33554456 Statistics:MT Count TotalSize Class Name 00007ffde2ac8538 4 62914656 System.Int32[] Total 4 objects 从信息中看(16777240 33554456)byte 48M按照刚才的理论这个16777240的int[]应该是没有引用根的等待被GC回收所以用!gcroot 把两个 int[] 都打印出来。 0:000 !gcroot 0000024c10fe9c10 Found 0 unique roots (run !GCRoot -all to see all roots).0:000 !gcroot 0000024c11fe9c48 Thread 63dc:0000007b4abfee60 00007ffd85950938 ConsoleApp6.Program.Main(System.String[]) [C:\dream\Csharp\ConsoleApp1\ConsoleApp6\Program.cs 28]rbp-38: 0000007b4abfee88- 0000024c00002da0 System.Collections.Generic.List1[[System.Int32, mscorlib]]- 0000024c11fe9c48 System.Int32[]Found 1 unique roots (run !GCRoot -all to see all roots). 可以看到0000024c10fe9c10 确实是没有引用根也就验证了其实真正的是48M而不是32M翻了2倍哦。。。有点小恐怖。二如何压缩1. 系统提供的压缩机制回过头来看 Capacity 属性中的扩容机制你只需要将Capacity设置与Count平齐_items数组多余的虚占空间就给清掉了。static void Main(string[] args){var list1 Enumerable.Range(0, (int)Math.Pow(2, 22)).ToList();list1.Add(1);list1.Capacity list1.Count;Console.ReadLine();} 从图中可以看到数组中的 8388608-4194305 4194303 个int直接给灭掉了优化了空间。2. 自定义List其实问题的根源出在了扩容机制举个例子如果当length大于400w的时候默认情况下是翻倍成800w有时候根据你的业务不需要翻到800w其实500w就足够了这样300w的虚占就可以免掉所以必要的时候自己实现一个list然后灵活控制它的扩容机制妙哉妙哉~~~五总结明白扩容机制对你了解在大数据量下使用List还是非常有帮助的大家根据自己的场景合理化使用下一篇我们聊一聊HashSet。
http://www.zqtcl.cn/news/707209/

相关文章:

  • 上海崇明网站建设崇信县门户网站首页
  • 北京手机版建站系统开发学网页设计需要什么学历
  • 英文网站备案互联网排名前十的公司2021
  • 网站外部外链建设如何开发wordpress主题
  • 个人网站首页内容辽宁省建设网站
  • 二建证从住房建设厅网站调出流程需求分析 网站
  • 鞋子网站模板做网站开发学什么软件
  • 网站建设的需求客户中企动力科技股份有限公司招聘
  • 小程序定制 seo营销seo托管公司
  • 杭州网站设计公司联系亿企邦网站建设在电访销售话术
  • 安康网站开发公司报价网站开发人员考核
  • 谷歌网站 百度清苑住房和城乡建设局网站
  • 南宁世尊商贸网站建设如何查看一个网站是否备案
  • h5手机网站怎么做搜索引擎关键词怎么选
  • 弱电网站源码工程造价建设信息网站
  • 村级网站模板做公司永久免费网站什么好
  • 厦门做网站培训安康市电梯公司
  • 江苏水利建设网站排行榜百度
  • 营销导向的企业网站优化wordpress制作企业
  • 株洲网站建设公司wordpress资讯类主题破解版
  • 网站导航栏设计要求wordpress直达按钮
  • 网站建设寻找可以途径网站制作的目的
  • 私募基金网站建设wordpress快讯插件
  • 无锡网站搜索引擎优化校园二级网站建设
  • 用vps刷网站流量要怎么做云主机开网站教程
  • 个体户经营异常如何网上解除深圳seo云哥
  • 网站建设科研申报书沧州网站建设定制价格
  • 家纺营销型网站wordpress演示数据
  • 中卫建设厅网站中国纪检监察报
  • 网站建设费如何核算如何给网站做权重