ruby – 为什么不在inspect中列出内置类的子类的实例变量?
发布时间:2020-12-16 23:10:30 所属栏目:百科 来源:网络整理
导读:当我对内置类进行子类化时,为什么检查中的行为会发生变化.但是,当我将自定义子类化为子类时,却看不到. class MainErrorendclass AnotherTestError StandardError def initialize @label_test = "hey!" endendclass TestError MainError def initialize @labe
当我对内置类进行子类化时,为什么检查中的行为会发生变化.但是,当我将自定义子类化为子类时,却看不到.
class MainError end class AnotherTestError < StandardError def initialize @label_test = "hey!" end end class TestError < MainError def initialize @label_test = "hey!" end end a = AnotherTestError.new puts a.inspect # output: #<AnotherTestError: AnotherTestError> t = TestError.new puts t.inspect # output: #<TestError:0x007f99e12409f0 @label_test="hey!"> 解决方法
因为很多(大多数?全部?)内置类
>用C编写,和 例如, exc_inspect(VALUE exc) { VALUE str,klass; klass = CLASS_OF(exc); exc = rb_obj_as_string(exc); if (RSTRING_LEN(exc) == 0) { return rb_str_dup(rb_class_name(klass)); } str = rb_str_buf_new2("#<"); klass = rb_class_name(klass); rb_str_buf_append(str,klass); rb_str_buf_cat(str,": ",2); rb_str_buf_append(str,exc); rb_str_buf_cat(str,">",1); return str; } 有趣的是构建返回字符串.
static VALUE rb_obj_inspect(VALUE obj) { if (rb_ivar_count(obj) > 0) { VALUE str; VALUE c = rb_class_name(CLASS_OF(obj)); str = rb_sprintf("-<%"PRIsVALUE":%p",c,(void*)obj); return rb_exec_recursive(inspect_obj,obj,str); } else { return rb_any_to_s(obj); } } 它递归地包含具有名称和值的实例变量. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读