优化Ruby脚本效率实例分享

所属分类: 脚本专栏 / ruby专题 阅读数: 1274
收藏 0 赞 0 分享

profile.rb是为Ruby程序准备的profiler,它可以统计并输出各方法的运行时间,以便于找到程序执行的性能瓶颈。这次就用它来剖析脚本的运行时间。使用方法很简单,加上命令行选项-r profile就可以:

ruby -r profile rename.rb
运行结束后,会把统计信息输出到标准错误输出中。如下图所示:

profile统计的是各方法的运行时间,分为2类。第1种计算的是从方法调用到方法返回之间的时间,称为整体时间;第2种则是从整体时间中扣除在该方法中调用其它方法所耗费时间之后得到的时间,称为实际时间。输出信息每行中各字段含义如下(从左到右):

该方法执行时间占整体时间的百分比,比例越高越说明这行代码可能需要优化

整体时间的总和

实际时间的总和

被调用的次数

每次调用的平均实际时间(毫秒)

每次调用的平均整体时间(毫秒)

方法名

由上图可以看出,脚本执行的时间大部分耗在了循环上。解决方法有两个:消除循环或减少循环次数。前者很难实现,暂且还没有想到办法,也许根本就没有可能。脚本中mapping的大小为2685,所以每修改一个文件名需要执行2685次循环,且循环中的encode和gsub!都是耗时操作。通常文件名的长度不超过30个字符,通过遍历文件名中每个字符的方式重命名就可以把循环次数缩减到不超过30次。

修改代码后重新执行分析命令,得到的结果是脚本运行时间从379395秒优化到2418秒,性能整整提升了156倍,达到2个数量级的效果。

更多精彩内容其他人还在看

Linux系统上配置Nginx+Ruby on Rails+MySQL超攻略

这篇文章主要介绍了Linux系统上配置Nginx+Ruby on Rails+MySQL超攻略,用到了RVM,此种服务器搭建配置极力推荐!需要的朋友可以参考下
收藏 0 赞 0 分享

在Ruby on Rails中使用Markdown的方法

这篇文章主要介绍了在Ruby on Rails中使用Markdown的方法,不过依赖于pygments.rb这个工具,事先得安装Python,需要的朋友可以参考下
收藏 0 赞 0 分享

在博客中屏蔽垃圾留言的简单方法

这篇文章主要介绍了在博客中屏蔽垃圾留言的简单方法,作者以Ruby on Rails搭建的博客应用为例,需要的朋友可以参考下
收藏 0 赞 0 分享

快速安装Ruby on Rails的简明指南

这篇文章主要介绍了快速安装Ruby on Rails的简明指南,Rails是Ruby上人气绝对最高的web开发框架,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby版本管理工具RVM的安装和使用教程

这篇文章主要介绍了Ruby版本管理工具RVM的安装和使用教程,本文示例基于类Unix的系统环境,需要的朋友可以参考下
收藏 0 赞 0 分享

使用rbenv来管理Ruby版本的方法

这篇文章主要介绍了使用rbenv来管理Ruby版本的方法,文中示例基于Mac OS系统进行演示,需要的朋友可以参考下
收藏 0 赞 0 分享

浅析Ruby的源代码布局及其编程风格

这篇文章主要介绍了浅析Ruby的源代码布局及其编程风格,意为给大家推荐一种最为普通的Ruby代码编写风格,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby编程中的语法使用风格推荐

这篇文章主要介绍了Ruby编程中的语法使用风格推荐,好的代码书写风格有助于debug等工作的进行,需要的朋友可以参考下
收藏 0 赞 0 分享

Ruby编程中的命名风格指南

这篇文章主要介绍了Ruby编程中的命名风格指南,包括变量和自定义方法等的常用命名格式,需要的朋友可以参考下
收藏 0 赞 0 分享

编写Ruby代码注释时需要注意的一些问题

这篇文章主要介绍了编写Ruby代码注释时需要注意的一些问题,特别是在团队协作时好的注释能大大增加代码的可读性,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多