只是一个简短的问题。我在文档中找不到它。如果我使用标准的begin...rescue,我如何将所有错误或堆栈跟踪打印到rescue中?例如:begindoxrescueputserrorsend有什么想法吗? 最佳答案 我知道至少有两种方法可以得到错误。第一种是使用全局变量:$!始终设置为发生的最后一个错误。第二种是在救援时明确捕获错误:begin#dosomethingthatfails...rescue=>error#errorand$!areequivalenthereend任何一个都可以让您使用以下任一方法检查或打印出回溯:
如何在不更改ruby类的情况下向异常消息添加信息?我目前使用的方法是strings.each_with_indexdo|string,i|begindo_risky_operation(string)rescueraise$!.class,"Problemwithstringnumber#{i}:#{$!}"endend理想情况下,我还想保留回溯。有没有更好的办法? 最佳答案 要重新引发异常并修改消息,同时保留异常类及其回溯,只需执行以下操作:strings.each_with_indexdo|string,i|begindo_
我正在尝试通过捕获异常来提高我的Ruby技能。我想知道当您有多个方法调用时重新引发相同类型的异常是否很常见。那么,下面的代码有意义吗?是否可以重新引发相同类型的异常,还是我不应该在process方法中捕获它?classLogodefprocessbegin@processed_logo=LogoProcessor::create_image(self.src)rescueCustomExceptionraiseCustomExceptionendendendmoduleLogoProcessordefself.create_imageraiseCustomExceptionifsome
我似乎找不到太多关于自定义异常类的信息。我所知道的你可以声明你的自定义错误类,让它继承自StandardError,这样它就可以被rescued:classMyCustomError这允许您使用以下方式提高它:raiseMyCustomError,"Amessage"稍后,在救援时收到该消息rescueMyCustomError=>eputse.message#=>"Amessage"我不知道的事我想为我的异常提供一些自定义字段,但我想从父类继承message属性。我发现阅读onthistopic@message不是异常类的实例变量,所以我担心我的继承不起作用。任何人都可以给我更多的细
我有一些代码需要在ruby中拯救多种类型的异常:begina=randifa>0.5raiseFooExceptionelseraiseBarExceptionendrescueFooException,BarExceptionputs"rescued!"end我想做的是以某种方式将我想要拯救的异常类型列表存储在某处并将这些类型传递给救援子句:EXCEPTIONS=[FooException,BarException]然后:rescueEXCEPTIONS这是否可能,如果不对eval进行一些真正的hack-y调用,这是否可能?考虑到我在尝试上述操作时看到TypeError:clas
在技术、哲学、概念或其他方面有什么区别raise"foo"和raiseException.new("foo")? 最佳答案 从技术上讲,第一个引发RuntimeError,消息设置为"foo",第二个引发异常,消息设置为"foo".实际上,使用前者和使用后者之间存在显着差异。简单地说,您可能想要一个RuntimeError不是Exception.没有参数的救援block将捕获RuntimeErrors,但不会捕获Exception秒。所以如果你提出Exception在您的代码中,此代码不会捕获它:beginrescueend为了ca
我通过了一个长期运行的遗留ruby程序,该程序多次出现begin#dosomethingrescueException=>e#halttheexception'sprogressend贯穿其中。如果不追踪每一个可能的异常,这些异常可能正在处理(至少不是立即处理),我仍然希望能够使用CtrlC.而且我希望以一种只增加代码的方式这样做(这样我就不会影响现有的行为,或者在运行过程中错过其他捕获的异常。)[CtrlC是SIGINT,或SystemExit,这似乎等同于SignalException.new("INT")在Ruby的异常处理系统中。classSignalException,这
我一直在尝试找出记录堆栈跟踪的正确方法。我遇到了this链接指出logger.error$!,$!.backtrace是要走的路,但这对我不起作用log_error。根据文档,我看不出将第二个参数传递给错误方法是如何工作的,因为rails使用的ruby记录器只接受一个参数。奇怪的是(或者可能不是)第二个论点被接受了,没有任何口译员的提示。但是,我传递给它的任何内容都将被忽略。谁能解释一下我错过了什么?对错误的第二个论点是什么以及是什么吞噬了它有什么见解吗? 最佳答案 如果您查看ActiveSupport中BufferedLogg
我有一个字符串,例如'123',我想将它转换为整数123。我知道您可以简单地执行some_string.to_i,但这会将'lolipops'转换为0,这不是我的效果心里。当我尝试转换一些无效的东西时,我希望它在我的脸上爆炸,伴随着一个美好而痛苦的Exception。否则,我无法区分有效的0和根本不是数字的东西。编辑:我一直在寻找没有正则表达式欺骗的标准方法。 最佳答案 Ruby内置了这个功能:Integer('1001')#=>1001Integer('1001nights')#ArgumentError:invalidvalue
Ruby有两种不同的异常机制:Throw/Catch和Raise/Rescue。为什么我们有两个?什么时候应该使用一个而不是另一个? 最佳答案 raise、fail、rescue和ensure处理错误,也称为异常(exception)throw和catch是控制流Unlikeinotherlanguages,Ruby’sthrowandcatcharenotusedforexceptions.Instead,theyprovideawaytoterminateexecutionearlywhennofurtherworkisneed