我需要一个像Hash一样工作的类,但不一定具有所有Hash方法。我读到过将像Hash这样的核心类子类化不是一个好主意。不管这是不是真的,做这种事情的最佳实践是什么?#(a)subclassHash,addnewmethodsandinstancevariablesclassBook我知道Ruby有不止一种方法来完成给定的任务,但是在相对简单的情况下,对于上述方法中的哪一种更可取,是否有任何通用规则? 最佳答案 如果我绝对不希望类哈希对象具有某些哈希方法,那么我会将对象包装在我自己的类中,并且只公开我希望它具有的方法(您的选项b)。如
我正在编写使用Object.const_set创建新类的Ruby代码,它非常适合创建新类和实例化它们的实例。但我希望这些新类继承self已经硬编码的类。我找不到方法来做到这一点。这是我的代码:defcreate_model_class(klass_name,klass_vars)klass=Object.const_set(klass_name,Class.new)klass.class_evaldodefine_method(:initialize)klass_vars.each_with_indexdo|name,i|instance_variable_set("@"+name[i
如果我有4个具有以下层次结构的类:classMainClass如何在不遍历和创建每个其他类的实例的情况下获得MainClass的子类列表?在新的IRBsession中,我可以进去说irb(main)>MainClass.descendants=>[]但是,如果我遍历并创建每个子类的实例,我将看到以下内容irb(main)>SubClassA.new=>#irb(main)>SubClassB.new=>#irb(main)>SubClassC.new=>#irb(main)>MainClass.descendants=>[SubClassA(...),SubClassB(...),Su
我如何创建自己的类来代替IO,例如为某些接受类似IO参数的代码重定向/捕获输入/输出?IO本身似乎耦合到OS文件描述符,我所知道的唯一一个模仿它而不对其进行子类化的类是StringIO,它似乎只是重新实现了整个接口(interface)。我认为该语言会提供一种直接的方法来执行此操作,但我找不到有关该主题的任何信息。是否有像Enumerable那样在一些基元之上实现接口(interface)的混合宏? 最佳答案 我怀疑我遗漏了什么,但假设情况并非如此......为什么子类化不是一种选择?你能不能只重写IO中需要表现不同的部分?clas
在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中
比方说我有我的课叫a=Person::User::Base如何只获取最后一个名为Base的子类。我知道如何做到这一点的方式是:a.to_s.split('::').last=>"Base"有没有更好的办法? 最佳答案 如果您使用Rails(ActiveSupport):a.to_s.demodulize如果您使用POR(plain-ol-Ruby),是的,这是您的方式:a.to_s.split('::').last 关于ruby-on-rails-获取子类的名称,我们在StackOver
classMaindefsay_helloputs"Hello"endprivatedefsay_hiputs"hi"endendclassSubMain输出:hiTesting 最佳答案 区别在于在ruby中你可以隐式调用子类中的私有(private)方法而不是显式调用。Protected可以双向调用。至于为什么?我猜你得问问Matz。例子:classTestMainprotecteddefsay_holaputs"hola"enddefsay_ni_haoputs"nihao"endprivatedefsay_hiputs"hi
我有如下代码:classAprivatedefp_methodputs"I'maprivatemethodfromA"endendclassBError:Privatemethodcannotbecalledb.some_method#=>I'maprivatemethodfromAb.some_method调用类A中定义的私有(private)方法。如何在继承它的类中访问私有(private)方法?这种行为在所有面向对象的编程语言中都一样吗?Ruby是如何进行封装的? 最佳答案 这是来自thissource的简要说明:Public
我有一个具有单个属性:contents的Pointer类,它指向MyObject类的对象。classMyObjectdefhello;"hello"endendclassPointerattr_reader:contentsdefinitialize(cont);@contents=contend#perhapsdefinesomemorestateend我希望我的Pointer能够self复制。我知道#dup方法是默认定义的,而#clone方法应该被覆盖以便能够进行深度复制。但是在这里,副本不必太深。所以,我遇到的第一个难题是,我是否应该重写#dup方法,因为我真的不想复制我的Poi
我为String的子类覆盖了=~方法:classMyString重写的方法在某些情况下被正确调用:r=/abc/s=~r#=>"Overriddenmethod."s.send(:=~,r)#=>"Overriddenmethod."s.send(:=~,/abc/)#=>"Overriddenmethod."而在其他情况下它被绕过,而是调用String#=~:s=~/abc/#=>0s=~(/abc/)#=>0我可以在Ruby1.8.7、2.1.0上重现这些结果。有人知道为什么会这样吗?是错误吗? 最佳答案 在String#=~的