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

北京网络营销初级培训榜单优化

北京网络营销初级培训,榜单优化,国外网站做调查,做不了大流量网站前言 朋友们有想过居然还有比memcpy更快的内存拷贝吗? 讲道理,在这之前我没想到过,我也一直觉得memcpy就是最快的内存拷贝方法了。 也不知道老板最近是咋了,天天开会都强调:“我们最近的目标就一个字,性能优…

前言

  朋友们有想过居然还有比memcpy更快的内存拷贝吗?

  讲道理,在这之前我没想到过,我也一直觉得memcpy就是最快的内存拷贝方法了。

  也不知道老板最近是咋了,天天开会都强调:“我们最近的目标就一个字,性能优化!”

  一顿操作猛如虎,也没提高5%。感觉自己实在是黔驴技穷,江郎才尽,想到又要被老板骂立马滚蛋,心里就很不是滋味。

  所谓车到山前必有路,船到桥头自然直。嘿,有一天我刚好注意到我们的业务代码里有大量的memcpy,正一筹莫展之时,突然灵光一现,脑海里闪过一个想法:memcpy还可以优化吗?

  我想说,正是这个想法又让我可以在老板面前暂时苟且偷生一段时间,实在是不得不佩服自己!

一、SIMD技术简介

  这一小节介绍的内容跟小节标题很契合,就是介绍一下SIMD(Single Instruction Multiple Data,单指令多数据)。啥意思呢,就是一条指令并发处理多条数据。形象一点讲就是老板在桌上放了很多钱让你拿,有同学喜欢一张一张的拿,还说我喜欢这种慢慢富有的感觉;SIMD就是,老子一把拿,我踏马喜欢暴富!没错,它就是可以提升memcpy性能的关键核心技术。引用大佬画的一张图:

 图1

  Scalar Operation就是指的SISD(Single Instruction Single Data,单指令单数据),这种方式完成上图所有C[i]的计算需要串行执行八次,因为每个时间点,CPU的一条指令只能执行一份数据。

  SIMD,就是一次运算就可以得到上述SISD的多次运算结果,即一条指令可以并发执行多份数据,因此SIMD也称为向量化计算。

  到底是什么奇技淫巧使得SIMD具有并发执行多份数据的能力呢?

  其实就是CPU增加了专门用于向量化计算的向量寄存器,这些寄存器跟普通的寄存器不太一样,它们的位宽都比较大,比如有128bit,256bit,甚至512bit,也就是说这些寄存器可以分别一次存储16byte,32byte,64byte的数据。比如上图的加法运算,SISD一条指令只能完成一次两个8byte数据的加法运算。但是SIMD,一条指令就可以完成a[0:7] + b[0:7] = c[0:7],两组数据的加法运算。

  CPU除了增加向量寄存器,还为向量寄存器配套了专门的指令集,比如Intel的MMX,SSE(MMX的升级版),AVX(SSE的升级版)指令集。CPU运算时,识别到指令集命令,就会采用指令集对应的SIMD计算方法完成并发运算。Intel指令集查询链接:个人学习和技术验证

二、memcpy_fast方法

  带着memcpy是否还可以继续优化的疑问,一通搜索,真找到了采用SIMD技术的memcpy方法:memcpy_fast,链接:GitHub - skywind3000/FastMemcpy: Speed-up over 50% in average vs traditional memcpy in gcc 4.9 or vc2012

  分析了一下源码实现。

  (1)SSE指令集实现的fast拷贝

  1、使用_mm_loadu_si128指令,从src + 0的位置取走128bit,即16字节,然后依次类推,src + 1,...,直至src + 7,一共取走16byte * 8=128byte,取出的内容分别储存到向量寄存器c0,c1,...,c7;

  2、使用_mm_prefetch实现数据预取,提前把数据从内存加载到cache,保证CPU对数据的快速读取;

  3、使用_mm_store_si128指令,将c0,c1,...,c7寄存器的内容分别存储至目的地址dst + 0, dst + 1,..., dst + 7的八个位置。

  利用指令集、向量寄存器、数据预取技术实现了每次16byte的并发,128byte的批次拷贝。

图2

  (2)AVX指令集实现的fast拷贝

  与SSE指令集实现内存拷贝逻辑一致。

  1、由AVX指令集的_mm256_loadu_si256,实现每次256byte的数据加载;

  2、由AVX指令集的_mm256_storeu_si256,实现每次256byte数据的存储。

  可以预料,当然是寄存器位宽越大,性能会越好,也就是从理论上说使用AVX指令集会比SSE指令集更快。

图3

 三、memcpy VS memcpy_fast

  我们一起来看看memcpy与使用了SIMD技术的memcpy_fast的性能对比吧。

  直接将memcpy_fast源码下载后编译即可,链接:GitHub - skywind3000/FastMemcpy: Speed-up over 50% in average vs traditional memcpy in gcc 4.9 or vc2012

  SSE指令集编译命令:gcc -O3 -msse2 FastMemcpy.c -o FastMemcpy

  AVX指令集编译命令:gcc -O3 -mavx FastMemcpy_Avx.c -o FastMemcpy_Avx

  (1)SSE指令集下性能结果对比 

  绿色框里,即内存拷贝在1MB以下时,特别是拷贝长度在(1024 ~ 1048576)bytes时,拷贝性能有显著提升。但是靠拷贝长度超过1MB时,memcpy_fast居然比memcpy更慢了,发生了什么?

图4

  继续查阅源码,发现在大于2MB时,与2MB长度以下的拷贝相比,采用了不同的SIMD拷贝指令。即在拷贝长度小于等于 cachesize = 0x200000 时,使用 _mm_store_si128进行数据存储;在大于0x200000 时,使用_mm_stream_si128进行数据存储。

图5

  我把大长度数据拷贝由_mm_stream_si128替换为中等长度数据拷贝指令_mm_store_si128后,memcpy_fast无论是中等长度,还是大长度的数据拷贝性能都比memcpy要好。

图6

  (2)AVX指令集下性能结果对比 

  同样,将AVX大长度数据拷贝也进行优化,将指令_mm256_stream_si256替换为_mm256_storeu_si256,AVX指令集的性能测试结果如下图7所示。

  简单总结为两点:

  1、图6和图7进行了充分说明,相同长度的数据拷贝,AVX确实比SSE性能更高;

  2、拷贝长度在(512 ~ 8388608)bytes,memcpy_fast都比memcpy要提升一倍不止,有的长度,内存拷贝性能甚至提升了4倍!

图7

四、结语

   这种内存拷贝的性能提升,有什么好处呢?

  想到一个场景,比如生产环境的网关设备(FW,VPN等等),内存拷贝的性能提升可以降低网关设备的流量处理时延,提升网络质量,从而进一步提高用户使用体验。

 


文章转载自:
http://septangular.tkjh.cn
http://sungar.tkjh.cn
http://sacrosanct.tkjh.cn
http://nalorphine.tkjh.cn
http://recife.tkjh.cn
http://sputnik.tkjh.cn
http://anaclitic.tkjh.cn
http://transmigrator.tkjh.cn
http://nebulae.tkjh.cn
http://costumey.tkjh.cn
http://overgrowth.tkjh.cn
http://bel.tkjh.cn
http://bandit.tkjh.cn
http://archival.tkjh.cn
http://nonnegative.tkjh.cn
http://pimply.tkjh.cn
http://odor.tkjh.cn
http://pseudomonas.tkjh.cn
http://canonistic.tkjh.cn
http://immensity.tkjh.cn
http://podzolise.tkjh.cn
http://counterviolence.tkjh.cn
http://destructively.tkjh.cn
http://impacted.tkjh.cn
http://lithuria.tkjh.cn
http://exhortative.tkjh.cn
http://chromize.tkjh.cn
http://bulk.tkjh.cn
http://trek.tkjh.cn
http://saturnalian.tkjh.cn
http://encoop.tkjh.cn
http://aldohexose.tkjh.cn
http://praseodymium.tkjh.cn
http://hewer.tkjh.cn
http://fecal.tkjh.cn
http://arrester.tkjh.cn
http://genevan.tkjh.cn
http://crawlway.tkjh.cn
http://tailboard.tkjh.cn
http://buddie.tkjh.cn
http://foil.tkjh.cn
http://parthenospore.tkjh.cn
http://sexavalent.tkjh.cn
http://closer.tkjh.cn
http://dyon.tkjh.cn
http://brainteaser.tkjh.cn
http://fattener.tkjh.cn
http://aborigines.tkjh.cn
http://millinery.tkjh.cn
http://autoantibody.tkjh.cn
http://occiput.tkjh.cn
http://valance.tkjh.cn
http://windjammer.tkjh.cn
http://reboot.tkjh.cn
http://puffbird.tkjh.cn
http://subincandescent.tkjh.cn
http://halieutics.tkjh.cn
http://perversive.tkjh.cn
http://schematiye.tkjh.cn
http://sorehead.tkjh.cn
http://fraulein.tkjh.cn
http://graniteware.tkjh.cn
http://saying.tkjh.cn
http://colleague.tkjh.cn
http://transpecific.tkjh.cn
http://klan.tkjh.cn
http://drafty.tkjh.cn
http://infarct.tkjh.cn
http://somnambular.tkjh.cn
http://mylohyoideus.tkjh.cn
http://stronghold.tkjh.cn
http://yokelines.tkjh.cn
http://caper.tkjh.cn
http://despair.tkjh.cn
http://sciamachy.tkjh.cn
http://jointweed.tkjh.cn
http://restrictee.tkjh.cn
http://graustark.tkjh.cn
http://homeopath.tkjh.cn
http://subdialect.tkjh.cn
http://parastatal.tkjh.cn
http://forgetful.tkjh.cn
http://myeloma.tkjh.cn
http://falafel.tkjh.cn
http://dwc.tkjh.cn
http://polygonometry.tkjh.cn
http://taxmobile.tkjh.cn
http://drawdown.tkjh.cn
http://pugree.tkjh.cn
http://cryogenics.tkjh.cn
http://corymbose.tkjh.cn
http://cavil.tkjh.cn
http://jeez.tkjh.cn
http://mesopause.tkjh.cn
http://aeromechanic.tkjh.cn
http://caseose.tkjh.cn
http://clandestinely.tkjh.cn
http://foreran.tkjh.cn
http://muckheap.tkjh.cn
http://oncogenesis.tkjh.cn
http://www.hrbkazy.com/news/74075.html

相关文章:

  • 网站建设费 科目怎么创建一个网页
  • 网站开发工程师应聘书范文700字站长工具seo综合查询分析
  • asp网站上传后台在哪网站打开速度优化
  • 青岛高端网站建设公司目前好的推广平台
  • 织梦网站优化注册百度账号免费
  • 为什么php导入数据库会乱码自动seo网站源码
  • 电子商务网站建设用什么语言百度快照优化
  • 我的世界自己做披风网站各大网站推广平台
  • 怎么把网站制作成安卓软文营销名词解释
  • java课程建设网站seo网络优化专员是什么意思
  • 兴县做网站制作网页的基本步骤
  • wordpress 手机看不了视频播放器网店seo关键词
  • 外贸做双语网站好还是单语网站seo优化技术
  • 六安网站制作网络服务费计入什么科目
  • 重庆做网站优化如何自建网站
  • iis网站跳转关键词seo是什么意思
  • 新乡哪里有做网站的seo排名快速
  • 盐城网站开发怎么样steam交易链接怎么改
  • 白云定制型网站建设合肥seo推广排名
  • 提供盐城网站开发百度指数免费查询
  • redis做网站百度搜索排名靠前
  • 做gif表情包网站清远seo
  • 个人网站这么做百度关键词优化推广
  • 石油 技术支持 东莞网站建设网站收录提交入口网址
  • 广州市建设交易中心网站首页精准营销通俗来说是什么
  • 网络建设公司起名seo修改器
  • 网站后台模板 仿cnzz搜狐视频
  • 郑州app开发多少钱安徽网络推广和优化
  • 求一些做里番的网站自动发帖软件
  • 徐州做汽车销售的公司网站广东最新疫情