设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 手机 数据 公司
当前位置: 首页 > 服务器 > 搭建环境 > Windows > 正文

CPU通俗演义及代码级性能优化实例分析

发布时间:2019-07-26 08:27 所属栏目:117 来源:SunnyZhang
导读:做任何事情要形成自己的方法体系,这样在做事情的时候才能游刃有余。前面文章我们简单介绍了一个简单的例子,说明了代码开发中应该如何保证程序的性能。今天我们将更加深入的介绍如何在代码层面提升程序的性能。并且我们总结为几种情况,这样在以后开发中

做任何事情要形成自己的方法体系,这样在做事情的时候才能游刃有余。前面文章我们简单介绍了一个简单的例子,说明了代码开发中应该如何保证程序的性能。今天我们将更加深入的介绍如何在代码层面提升程序的性能。并且我们总结为几种情况,这样在以后开发中就可以套用。另外,本节我们主要介绍的是代码级的性能优化,关于涉及操作系统甚至整个分布式大系统的性能优化我们另外单独介绍。

程序是运行在CPU之上的,因此在介绍性能优化之前我们有必要介绍一下CPU的内核结构。在前文中我们对CPU进行了简化处理(如图1),实际上CPU的结构非常复杂,毕竟一颗CPU由几十亿个晶体管组成的。

CPU通俗演义及代码级性能优化实例分析

CPU通俗演义

CPU的作用很好理解,它就是一个数据加工部件。CPU就像一个大型的工厂,它将原料(数据)加工成半成品和成品;而内存则像一个大型的仓库。虽然CPU与内存都在机箱中,但CPU访问内存中的数据并不是非常方便,就好像工厂和大型仓库之间的距离,有几百公里。从仓库向工厂运算原材料需要用火车才行,运输一次材料可能要几个小时。

CPU通俗演义及代码级性能优化实例分析

在这个大型工厂(CPU)里面有很多东西,最为重要的就是车间(CPU核)、生产线(ALU)、物料暂存区(寄存器)、工厂小仓库(缓存)等内容。为了更好理解上面这些内容的关系,这里做了一个简化的平面图。

CPU通俗演义及代码级性能优化实例分析

工厂加工产品所需要的原材料需要从外面的大型仓库运输过来。由于从工厂外大型仓库到工厂的距离比较远,耗时比较长,因此总是有计划的,批量的将物料从工厂外的大仓库运输到工厂内的小仓库。工厂的车间突然需要一些原材料,那就只能让火车重新跑一趟了。

运输过来的原材料不能乱放,否则要是下雨刮风啥的不就损坏了。因此,原材料会被统一的放在工厂内的小仓库(CPU缓存)里面,各个车间根据需要从小仓库运输原材料到车间。

在车间有个暂存区(寄存器),用于存放从小仓库运过来的材料。当然暂存区除了放原材料之外,还会放一些半成品和成品。车间有车间的秩序,不能乱放,否则会出问题的。暂存区是很有必要的,要不然需要点材料就去仓库拿,那不得类似工人啊。

CPU通俗演义及代码级性能优化实例分析

有了原材料之后,工人就可以将原材料放到生产线(ALU)上进行生产了。生产完成的成品又会放回暂存区,然后运输出去。暂存区和生产线都在车间里面,搬运原材料和成品都很快,几乎是一两分钟就可以完成。

关于流水线

为了提高产品生产速度,在一个车间里面通常是有多个生产线的。每一个生产线的大概流程是运输原材料、原材料预处理(比如撕掉包装或者切成小块等)、原材料加工和成品运回暂存区等步骤。CPU也是有类似的流水线的,任何一个指令都要经过读取指令、译码、执行和写回(寄存器或者内存)等。

以一个生产黄桃罐头的车间为例,在这个车间里面要同时生产罐头瓶、罐头瓶盖和糖水黄桃(这里是假设,实际工厂不是这样)。因此,也就有生产罐头瓶的流水线、生产罐头瓶盖的流水线和生产糖水黄桃的流水线。通常我们安排的流程是先生产罐头瓶和瓶盖,这样生产的糖水黄桃就可以装瓶完成成品了。但是,有的时候可能运送暂存区或者工厂的小仓库没有玻璃了,这样就没法生产罐头瓶。不过没关系,车间还是可以先生产糖水黄桃的,生产完之后先放到暂存区,等什么时候罐头瓶生产完之后在装瓶。

上面这个流程其实就是所谓的指令乱序。也就是CPU在执行指令的时候并不是按我们写代码的顺序执行的,而可能会打乱顺序。比如下面这段代码,由于两行代码之间没有任何依赖,因此在CPU中可能会先执行b=2,后执行a=1。

  1. int a = 1; 
  2. int b = 2; 

存储的金字塔结构

另外一个比较重要的知识点是需要知道软件开发涉及的存储金字塔。具体如图所示,其中寄存器、一级缓存、二级缓存和三级缓存是CPU内部的部件,然后是内存和磁盘。最后是远程存储,比如SAN、NAS或者对象存储或者云计算中的云盘等存储都属于远程存储。

CPU通俗演义及代码级性能优化实例分析

通常来说越往金字塔底部,容量越大,但延迟也越大,性能越差。这里面有个特例,就是本地存储和远程存储,如果远程存储采用的介质与本地相同,则肯定远程存储性能要差一些。但当前有些分布式存储,通信链路采用RDMA,存储介质采用SSD,那么本地的机械磁盘就要比远程存储性能差了。

了解了这个结构之后,我们总结一下。其实性能问题总结起来就是一句话,尽量少的使用计算资源(比如不同的排序算法),尽量多的用金字塔顶部的部件存储要访问数据(比如文件系统的缓存)。

程序性能分析工具

正所谓:“欲善其事,必先利其器”。因此,要想进行性能优化,自然需要有相应的工具进行分析。本文仅针对Linux操作系统进行介绍,其它操作系统实在是不熟悉。在Linux操作系统下面,用的最多的性能分析工具恐怕非top莫属。

(1) top命令

top命令可以实时的观察进程的计算资源使用情况(CPU利用率)和整个系统的综合负载。如图是我们通过一个Python脚本模拟高负债程序,可以看到起CPU利用率已经达到100%。

CPU通俗演义及代码级性能优化实例分析

top工具可以帮助我们分析高度消耗计算资源的程序的性能。另外还有其它性能分析工具,比如ps、vmstat、mpstat和prstat等等。工具比较多,限于篇幅问题,本文暂时就不做介绍了。

性能优化方法总结

有了前面的准备知识后,下面我们进入正题。本节内容总结了在程序代码级别常见的问题,并结合实例给出了解决方法,下面我们逐个分析一下。

1. 优化程序代码结构

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读