草庐IT

Performance

全部标签

Ruby Array concat 与 + 速度?

我对Ruby的数组concat()与+操作进行了小型性能测试,concat()速度太快了。但是我不清楚为什么concat()这么快?有人可以帮忙吗?这是我使用的代码:t=Time.nowar=[]foriin1..10000ar=ar+[4,5]endputs"Timefor+"+(Time.now-t).to_st=Time.nowar=[]foriin1..10000ar.concat([4,5])endputs"Timeforconcat"+(Time.now-t).to_s 最佳答案 根据Rubydocs,不同之处在于:数组

ruby-on-rails - 何时在 Ruby on Rails 中使用内存

2008年7月中旬,Memoization被添加到Rails核心。用法演示是here.关于何时应该内存方法,以及每个方法的性能影响,我还没有找到任何好的例子。Thisblogpost,例如,建议通常根本不应该使用内存。对于可能具有巨大性能影响的内容,除了提供简单教程之外似乎没有其他资源。有没有人见过在自己的项目中使用memoization?哪些因素会让您考虑内存方法?在我自己做了更多研究之后,我发现在Rails核心中使用记忆化的次数非常多。这是一个例子:http://github.com/rails/rails/blob/1182658e767d2db4a46faed35f0b1075

ruby-on-rails - 哪个更快 : MRI Ruby or JRuby?

如果我使用RubyonRails,我应该安装MRI/YARVRuby还是JRuby?哪个更快? 最佳答案 最近的基准测试将JRuby置于领先地位,其次是MagLev、Rubinius,然后是MRI。基准测试很棘手。RubyBenchmarkSuite最常用于对Ruby进行基准测试。如果您删除任何实现失败的基准测试,您将得到下图。请注意,我使用的是几何平均数。这是一个更好的平均性能指标,因为它规范了异常值和机器规范。您可以运行的最佳基准将特定于您的应用。如果您正在寻找整体性能,您可能希望使用真正的线程,因此Rubinius或JRuby

ruby-on-rails - 如何调试慢速 Rails 应用程序启动时间?

我们的Rails应用程序在加载后速度很快,但启动速度非常慢。控制台、乘客等都需要将近10秒才能启动。似乎比应该的要长得多。我应该使用什么工具或方法来磨练最慢的部分?通常的嫌疑人是什么? 最佳答案 我知道这是一个老问题,但我最近遇到了加载时间的问题,这是我的gem分支,它帮助我找到了最慢的gem,这个gem的好处是它可以通过Rails控制台加载,并运行所有初始化程序。https://github.com/mark-ellul/Bumbler 关于ruby-on-rails-如何调试慢速Ra

Ruby 基准测试模块 : meanings of "user", "system"和 "real"?

试验Ruby的基准模块...>>Benchmark.bm(7){|b|b.report('Report:'){s='';10000.times{s+='a'}}}usersystemtotalrealReport:0.1500000.0100000.160000(0.156361)“用户”、“系统”、“真实”的含义是什么? 最佳答案 这些时间与Unixtime命令或其他典型基准测试工具报告的时间相同:user:执行用户空间代码(即:您的代码)所花费的时间,system:执行内核代码所花费的时间和真实:执行代码所花费的“真实”时间(即

ruby-on-rails - Rails 开发服务器很慢,需要很长时间才能加载一个简单的页面

关于Rails在开发模式下运行缓慢的类似帖子也有,但这些帖子中的解决方案都没有对我产生任何影响。我试过安装可以提高性能的gem并修改配置文件,但都没有成功。我刚开始使用Rails,所以我正在运行“Rails入门”指南中的启动应用程序,这是一个小博客。我已经按照推荐安装了Ruby1.9.3和Rails3.2.13。我在OS/X10.7.5上运行。当加载教程应用的起始页时,实际上只有1行文本和1个链接,需要20-40秒。对任何页面的每个后续请求都需要20-40秒。然而,当我查看服务器日志时,Rails所做的任何事情似乎都不会花费很长时间。日志中的事件之间的时间一直在占用。作为Rails的初

ruby - Ruby 2.0 中的垃圾收集器调整

我想知道用于ruby​​1.9.x的GC调优在2.0中是否仍然与GC的新实现相关。如果是这样,我们可以在新版本上配置什么新东西吗?我说的是以下设置RUBY_HEAP_MIN_SLOTS=600000RUBY_GC_MALLOC_LIMIT=59000000RUBY_HEAP_FREE_MIN=100000 最佳答案 这些GC调优参数有些困惑。REE(它是Ruby1.8.7的一个分支)introduceditsownparametersfirst,后来Ruby(从1.9.2开始)引入了它自己的(类似的)参数。Ruby1.9.3使它们可

ruby - Ruby 中数组和哈希的性能

我有一个程序可以存储一个类的多个实例,比如说多达10,000个或更多。类实例有几个我不时需要的属性,但其中最重要的一个是ID。classDocumentattr_accessor:iddef==(document)document.id==self.idendend现在,存储数千个此类对象的最快方法是什么?我曾经将它们全部放入一个文档数组中:documents=Array.newdocuments现在另一种方法是将它们存储在哈希中:documents=Hash.newdoc=Document.newdocuments[doc.id]=doc#etc在我的应用程序中,我主要需要查明文档是

ruby - 是什么让 Ruby 变慢了?

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭8年前。ImprovethisquestionRuby在某些事情上很慢。但它的哪些部分最有问题?垃圾收集器对性能的影响有多大?我知道我曾经有过单独运行垃圾收集器需要几秒钟的时间,尤其是在使用OpenGL库时。我在Ruby中使用过矩阵数学库,速度特别慢。ruby实现基础数学的方式有问题吗?Ruby中是否有任何无法有效实现的动态特性?如果是这样,其他语言如Lua和Python如何解决这些问题?最近有没有显着提高性能的工作?

ruby - 何时使用在 Ruby 中启动子进程的每种方法

1。``反引号定义于Kernel1。a)%x{}百分比X在parse.y中定义,参见discussion2。系统()Kernel#system3。fork()Kernel#fork,Process#fork4。打开()打开管道Kernel#open4.a.IO.popen()open()相同打开管道IO#popen4.b.打开("|-")叉到管道4.c.IO.popen("-")open("|-")的行为相同fork到管道参见discussion5。Open3.popen3()需要'open3'标准库Open36。PTY.spawn()需要'pty'标准库PTY7.Shell.tran