草庐IT

Python统计代码运行时间

全部标签

ruby - 在 Ruby 1.8.7 中显示时间减少到毫秒

我试图让我的应用程序显示时间精确到毫秒(例如11:37:53.231),但是1.8.7中的strftime似乎没有选项(http://ruby-doc.org/core-1.8.7/Time.html#method-i-strftime)。在Ruby>=1.9.3中,有%3N选项(http://ruby-doc.org/core-1.9.3/Time.html#method-i-strftime),但它不在1.8.7的文档中,而且似乎也不起作用。这是我在Ruby1.8.7中得到的输出。cur_time=Time.now#=>MonJun2412:43:14+09002013cur_ti

ruby - 上帝不会注册正在运行的自定义服务

我有一个Rails网站和一个在linodevps上运行的小型Minecraft服务器。我正在运行minecraft作为基于init.d文件的ram服务器的自定义服务。因为我使用God来监控我的Rails网站,所以我想我也会将它用于我的世界,但它似乎无法以任何方式识别该服务。条件检测不到它的存在。:process_running始终返回false,无论它是否正在运行,并且在未运行时无法启动它。更让人困惑的是:memory_usage和:cpu_usage始终为零。我的/etc/init.d/minecraft文件在这里:http://pastie.org/2760483它工作得非常好,“

ruby-on-rails - Ruby 内置的#permutation 和#repeated_permutation 方法的时间复杂度是多少?

我一直想知道一些Ruby内置方法的时间复杂度,尤其是这两个。我认为我自己能想到的最好的排列方法是Θ(n·n!),Ruby的内置性能更好吗?如果是这样,请帮助我了解他们的算法。 最佳答案 排列Array#permutation返回一个带有n!数组的枚举器,因此时间复杂度至少为O(n!)。我写了这个方法:defslow_method(n)(1..n).to_a.permutation.eachdo|p|pendend它不对p做任何事情,期望强制生成所有排列。构建所有排列的数组会占用太多内存。此方法在n为10到13时被调用了10次,平均秒

ruby-on-rails - 如何测试 Rails ERB 模板的代码覆盖率?

我只是为旧版Rails应用程序构建测试套件。simplecovgem非常适合查找需要测试覆盖的应用程序的暗角(或者可能完全未使用但可以删除的暗角)。我通过在test/test_helper.rb的顶部包含以下内容来调用simplecov:require'simplecov'SimpleCov.start('rails')问题是这不会检查模板中嵌入的所有代码。那里有各种各样的垃圾,我敢肯定其中很多都可以删除,但如果代码覆盖工具可以将我指向未使用的位,那就太好了。对Ruby1.9的Coverage库进行的一些实验让我相信,只有将模板以某种方式预编译为Ruby代码,保存在Ruby源文件中,然

ruby - 有没有人想出一种方法来在多个浏览器/网络驱动程序上运行相同的 cucumber 场景?

我正在使用Cucumber+capybara进行一些网络自动化测试。我希望能够连接我自己的标签(类似于场景之前的@all_browsers)并让它针对我设置的网络驱动程序列表运行(celerity,firefox上的selenium,ie和chrome)。我不想在前面用4个不同的标签写4次不同的场景。我已经研究过尝试使用我通过以下方式注册的新驱动程序来执行此操作:Capybara.register_driver:all_browsersdo|app|#Whatwouldevenworkinhere?Idon'tthinkanythingwill.end然后跟进:Before('@all

ruby - 如何检查 ruby​​ 代码中的 ruby​​ 语法错误

我现在使用以下来检查语法错误:system"ruby-wcpath/to/file.rb"但是如果文件太多会很浪费时间(比如重构代码),所以我的问题是有没有办法在ruby代码中进行ruby语法检查? 最佳答案 在MRI下,你可以使用RubyVM::InstructionSequence#compile(relevantdocumentation)编译Ruby代码(如果有错误会抛出异常):2.1.0:001>RubyVM::InstructionSequence.compile"a=1+2"=>@>2.1.0:002>RubyVM::

ruby-on-rails - 如何让 Rake 任务在我的 Sinantra 应用程序/环境下运行?

我正在使用Sinatra,我想设置Rails具有的一些方便的rake任务,特别是rakedb:seed。我的第一遍是这样的:namespace:dbdodesc'Loadtheseeddatafromdb/seeds.rb'task:seeddoseed_file=File.join(File.dirname(__FILE__),'db','seeds.rb')system("rackshracksh是一个模仿Rails控制台的gem。所以我只是将种子文件中的代码直接输入其中。它有效,但显然并不理想。我想做的是创建一个环境任务,允许命令在Sinanta应用程序/环境下运行,如下所示:t

ruby - 每个功能前后是否有 cucumber 钩子(Hook)运行

有没有办法在每个带有特定标签的cucumber功能之前和之后运行特定的代码块?由于设置过程非常昂贵,我不想在每个场景之前运行它。 最佳答案 LukasMac的回答不适用于@变量。安德依官方cucumberwiki页面,我下面的示例工作并测试正常,下面的before钩子(Hook)每个功能只执行一次:Before('@my_feature_tag')dounless$dts_test_preparation_done#expensivesetupinmycasesetuplotsofdatabasetablesfortest$dts_

ruby - ruby代码是如何执行的

我最近开始学习Ruby。我知道Ruby是一种解释型语言(尽管“每种”语言都是因为它被CPU解释为机器代码)。但是ruby​​解释器如何将用Ruby编写的代码转换为机器码呢?我读过解释器不读取源代码,而是字节码,但是我永远不必像在Java中那样进行编译。那么,这是Ruby为您做的另一件事吗?如果是,它会在运行时生成字节码吗?因为您永远不会像在Java中那样获得.class文件。最重要的是,我阅读了关于即时编译器的所有内容,这些编译器显然对字节代码做了一些事情,因此它运行得更快。如果是上述情况,解释器是否首先扫描所有源代码,将其转换为字节码,然后在运行时使用JIT再次编译?最后,我不是在寻

ruby-on-rails - 在我的 Rails Controller 方法中运行线程

我有一组数据,我想在我的Rails应用程序中对其进行一些计算,每个计算都是相互独立的,所以我想对它们进行线程化,以便我的响应更快。这是我的ATM:defshow@stats=Stats.newThread.new{@stats.top_brands=#RESULTOFFIRSTCALCULATION}Thread.new{@stats.top_retailers=#RESULTOFSECONDCALCULATION}Thread.new{@stats.top_styles=#RESULTOFTHIRDCALCULATION}Thread.new{@stats.top_colors=#R