jjzjj

pry-stack_explorer

全部标签

arrays - Array#push 导致大数组出现 "stack level too deep"错误

我做了两个数组,每个数组有100万个项目:a1=1_000_000.times.to_aa2=a1.clone我试图将a2插入a1:a1.push*a2这将返回SystemStackError:stackleveltoodeep。但是,当我尝试使用concat时,我没有收到错误消息:a1.concata2a1.length#=>2_000_000我也没有得到splat运算符的错误:a3=[*a1,*a2]a3.length#=>2_000_000为什么会这样?我查看了Array#push的文档,它是用C语言编写的。我怀疑它可能在幕后进行一些递归,这就是它导致大型数组出现此错误的原因。这

javascript - `binding.pry` 用于 javascript 控制台?

在Ruby中,我可以在我的代码中的任何地方键入binding.pry,在那个执行点我的控制台将进入一个REPL,我可以在其中访问所有局部变量,可以进行更改并执行任意代码。例子:#foo.rbrequire'pry'n=5binding.pryputs"yournumberis#{n}"当我运行它时:$rubyfoo.rbFrom:/Users/cgenco/Desktop/foo.rb@line4:1:#foo.rb2:require'pry'3:n=5=>4:binding.pry5:puts"yournumberis#{n}"[1]pry(main)>n=100=>100[2]pr

ruby-on-rails - Rails 3.0 & Ruby 1.9.2rc : Rake commands return 'already initialized constant' & stack level too deep errors. 任何想法

我正在尝试在Ubuntu10.04上运行Rails3beta4和Ruby1.9.2rc。它最初有效,但在完成我的第一个bundleinstall/package之后,我现在在所有Rails项目中都遇到以下错误。即使是基本的“railsnewtestproject”后跟一个rake也会显示错误消息。简而言之,我很难过。非常感谢任何有关可能导致此问题的帮助。我唯一注意到的事情——可能相关也可能不相关——是~/.bundle文件中的目录是ruby​​/1.9.1。我的机器上没有安装1.9.1-只有1.9.2rc。ruby-v带回1.9.2(in/home/john/Websites/sand

ruby-on-rails - 运行 heroku create --stack cedar 时无法加载此类文件 -- readline (LoadError)

我正在尝试将我的Rails应用程序部署到Heroku以按照以下说明进行测试:http://devcenter.heroku.com/articles/rails3#prerequisites这是我要运行的命令:herokucreate--stackcedar我收到此错误消息:/home/sergio/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in`require':cannotloadsuchfile--readline(LoadError)from/home/s

ruby - 如何增加 ruby​​ 应用程序的堆栈大小。递归应用获取 : Stack level too deep (SystemStackError)

在stackoverflow.com上发布一个堆栈溢出问题,多么有趣:-)我正在运行一些递归Ruby代码,我得到:“堆栈级别太深(SystemStackError)”(我很确定代码有效,我没有陷入无限递归的死亡螺旋,但这不是重点)是否可以更改我的Ruby应用程序允许的堆栈深度/大小?如果这是Ruby中的限制,我不太明白,因为错误显示“堆栈级别”,这给我的印象是Ruby以某种方式计算堆栈的“级别”,或者它只是意味着堆栈满了。我已经尝试在Vista和Ubuntu下运行这个程序,结果相同。在Ubuntu下,我尝试使用“ulimit-s”将堆栈大小从8192更改为16000,但这并没有改变任何

ruby - 如何在 Sinatra 中使用 Pry?

我正在编写我的第一个Sinatra应用程序,并想使用Pry来检查/调试应用程序中发生的一些事情。我之前也没有使用过Pry,但我想尝试一下。我将如何开始在我的Sinatra应用程序中使用Pry? 最佳答案 总结在您的应用程序顶部使用require'pry'。只要您想进入交互式session,就在您的代码中调用binding.pry。有关使用Pry的信息,请参阅TurningIRBonitsheadwithPry和Prywiki。完成特定的交互式session后,键入exit或Ctrl-D;Sinatra将从中断处恢复运行。例子requ

ruby - Pry 中有 next 的等价物吗?

当使用pry作为调试器时,我没有看到直接转到下一行的方法。我所能找到的就是编辑方法并将binding.pry移动到下一行。有这样的功能吗?22:defscanpath23:@last_line_had_text,@files_read,@hands_read=nil,0,024:Find.find(path){|file_name|=>25:binding.pry26:read_file(file_name)iffile_name.include?(".txt")27:}28:end 最佳答案 Ctrl+D,可以跳到下一个break

ruby - 如何从 SystemStackError : stack level too deep? 获取回溯

在编写ruby​​代码时,我常常很难调试无限递归。有没有办法从SystemStackError中获取回溯?找出无限循环发生的确切位置?例子给定一些方法foo,bar和baz在循环中互相调用:deffoobarenddefbarbazenddefbazfooendfoo当我运行这段代码时,我只收到消息test.rb:6:stackleveltoodeep(SystemStackError).至少获取堆栈的最后100行会很有用,因此我可以立即看出这是foo之间的循环。,bar和baz,像这样:test.rb:6:stackleveltoodeep(SystemStackError)test

ruby-on-rails - rails : Logging the entire stack trace of an exception

我一直在尝试找出记录堆栈跟踪的正确方法。我遇到了this链接指出logger.error$!,$!.backtrace是要走的路,但这对我不起作用log_error。根据文档,我看不出将第二个参数传递给错误方法是如何工作的,因为rails使用的ruby​​记录器只接受一个参数。奇怪的是(或者可能不是)第二个论点被接受了,没有任何口译员的提示。但是,我传递给它的任何内容都将被忽略。谁能解释一下我错过了什么?对错误的第二个论点是什么以及是什么吞噬了它有什么见解吗? 最佳答案 如果您查看ActiveSupport中BufferedLogg

ruby-on-rails - 如何使用 Ruby Pry 跳出循环?

我在我的Rails应用程序中使用Pry。我在模型的循环内设置了binding.pry来尝试调试问题。例如:(1..100).eachdo|i|binding.pryputsiend当我键入quit时,它会进入下一次迭代并再次停止。有没有办法跳出循环,这样我就不必输入100次quit?目前我知道如何摆脱它的唯一方法是使用CTRL+C并重新启动应用程序。 最佳答案 要无条件退出Pry,请键入exit-program根据@Nick的评论编辑:同样有效:!!! 关于ruby-on-rails-如