草庐IT

c++ - 派生异常不继承构造函数

全部标签

ruby - Errno::EPIPE:引发破损管道异常

if@blockrd,wr=IO.pipe@pid=forkdo$0="ForkedchildfromPage#{@path}"rd.closeresult=@block.call(@resp.body)beginwr.writeMarshal.dump(result)endwr.close这是与fork共享管道的非常标准的方法,但是一旦rd.close被调用,它就会断开管道供wr使用。直到那条线,管道才能正常工作(我用Pry逐行运行它)。据我所知,关闭fork内的读取器以阻止它干扰发送EOF是一种很好的做法(我不知道为什么会这样,我只知道这是做法)。这是我调用到生产应用程序中的库的一

c - Ruby C 扩展开发人员的命名约定

在用C为ruby​​编写扩展时,我对遵循正确的命名约定很感兴趣。具体来说,我指的是将_p添加到谓词的函数名称以及为变量添加前缀m代表模块,c代表类等等。例如,如果我们想在C语言中定义一个像下面这样的谓词方法,我们应该在定义该方法的函数中使用_p作为后缀。classMyClassdefawesome?trueendend在C中:staticVALUEmy_extension_my_class_awesome_p(VALUEself){returnQtrue;}voidInit_my_extension(void){VALUEcMyClass=rb_define_class("MyClas

ruby - 使用类似 django 的液体 block /继承的 Jekyll 模板

我正在深入了解Jekyll,并希望将其用作通用前端开发平台,但遇到了Liquid模板语言的局限性,特别是它与Django模板的区别。我发现了liquid-inheritancegem,它添加了Django中最重要的Extends和Block语法。这篇博文进一步扩展了gem以适应Jekyll的文件系统:http://www.sameratiani.com/2011/10/22/get-jekyll-working-with-liquid-inheritance.html问题是它似乎没有以与Django完全相同的方式实现block,这实际上使gem变得无用。为了便于理解,我有两个名为par

ruby-on-rails - 单表继承还是类表继承?

我正在阅读有关类表继承(CTI)的文章,发现我总体上更喜欢它。我的问题是,单表继承(STI)是否有任何特定的用例,您可以在CTI上使用它?我读了http://rhnh.net/2010/07/02/3-reasons-why-you-should-not-use-single-table-inheritance据我所知,它很坚固。STI的用例是行为差异而非数据差异。 最佳答案 我想向您推荐我发现的一篇很棒的文章,其中清楚地解释了为什么以及何时使用CTI。LINK 关于ruby-on-ra

ruby - Ruby 中命名空间函数的最佳实践? (新手问题)

(StackOverflow告诉我这个问题是“主观的,可能会被关闭”……好吧,无论如何我都会试一试)我正在编写一堆辅助方法(用于TextMate包),我希望(并且我需要)将它们整齐地命名空间。这些方法实际上只是函数,也就是说,它们不会对自身作用域之外的任何东西进行操作,因此并不真正属于某个类。没有什么需要实例化。到目前为止,我一直在这样做,而且效果很好moduleHelpers::Foomodule_functiondefbar#...endendHelpers::Foo.bar#thisishowI'dliketocallthemethod/function但是这样会更好吗:1.跳过

ruby - 为什么 foo 不再是 nil - 或函数内函数

为什么在下面的代码片段中foo替换了它的定义?deffoodeffoo1endend第一次foo为nilfoo=>nilfoo.foo=>1现在,如果我再次调用foo:foo=>1如您所见,foo不再是nil。谁可以给我解释一下这个?谢谢。 最佳答案 deffoop"abouttoredeffoo"deffoo1endendfoo"abouttoredeffoo"=>nilfoo=>1此外,当您调用foo.foo时,您似乎在尝试访问内部的foo方法,但实际上并非如此。您的foo方法实际上是在Object上定义的,因此您实际上是在调用

ruby - Ruby 中的 DelegateClass 与类继承

有人可以通过DelegateClass提供一些关于何时使用委托(delegate)的见解吗?(例如Seller)以及何时在ruby​​中使用类继承(例如Seller)?classSeller当我查看Github上的RubyonRails源代码时,我发现了很多usesofDelegateClass. 最佳答案 有一些差异可以帮助深入了解使用哪种方法。1)您可以安全地委托(delegate)给基元(例如String),但不能总是安全地从它们继承如果您在Hash或String或Fixnum之上构建,使用DelegateClass会更安全>

ruby - 如何模拟 Ruby 模块函数?

如何在我的项目中模拟自写模块的模块功能?给定模块和功能moduleModuleA::ModuleBdefself.my_function(arg)endend这叫做像ModuleA::ModuleB::my_function(with_args)当它在我正在为其编写规范的函数中使用时,我应该如何模拟它?将它加倍(obj=double("ModuleA::ModuleB"))对我来说毫无意义,因为该函数是在模块上调用的,而不是在对象上调用的。我试过对它进行stub(ModuleA::ModuleB.stub(:my_function).with(arg).and_return(somet

ruby - 访问 OpenStruct 中不存在的属性时引发异常

我正在尝试弄清楚如何使OpenStruct的子类(或与此相关的任何类)或散列在我尝试访问尚未设置的属性时引发自定义异常.我无法让define_method和method_missing执行此操作,所以我不知道应该如何在Ruby中完成。这是一个例子:classRequest我可以想象它必须是这样的:classHash#iftryingtoaccesskey:#1)keyexists,returnkey#2)keydoesn'texist,raiseexceptionend编辑:存在的属性不应引发异常。我正在寻找的功能是让我可以自由访问属性,如果它不存在,我的自定义异常将被引发。

Ruby - 删除继承的方法

是否可以删除Ruby中的一些继承方法?我的意思是,我可以覆盖它,但还有其他方法吗?ClassABCenda=ABC.newputsa.id这里,方法id继承自Object以及其他方法,如tap、class、type等。我想删除此类方法。编辑:我使用的是Ruby1.8.7 最佳答案 是-undef_method:foo将阻止对方法foo的任何调用(与remove_method:foo对比,它从子,但仍向上传递继承链)。不过,为什么您要删除id之类的东西? 关于Ruby-删除继承的方法,我们