ruby – 为什么不在inspect中列出内置类的子类的实例变量?

前端之家收集整理的这篇文章主要介绍了ruby – 为什么不在inspect中列出内置类的子类的实例变量?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当我对内置类进行子类化时,为什么检查中的行为会发生变化.但是,当我将自定义子类化为子类时,却看不到.
  1. class MainError
  2. end
  3.  
  4. class AnotherTestError < StandardError
  5. def initialize
  6. @label_test = "hey!"
  7. end
  8. end
  9.  
  10. class TestError < MainError
  11. def initialize
  12. @label_test = "hey!"
  13. end
  14. end
  15.  
  16. a = AnotherTestError.new
  17. puts a.inspect # output: #<AnotherTestError: AnotherTestError>
  18.  
  19. t = TestError.new
  20. puts t.inspect # output: #<TestError:0x007f99e12409f0 @label_test="hey!">

解决方法

因为很多(大多数?全部?)内置类

>用C编写,和
> #incpect覆盖.

例如,@L_404_0@(StandardError的超类)定义#inspect如下:

  1. exc_inspect(VALUE exc)
  2. {
  3. VALUE str,klass;
  4.  
  5. klass = CLASS_OF(exc);
  6. exc = rb_obj_as_string(exc);
  7. if (RSTRING_LEN(exc) == 0) {
  8. return rb_str_dup(rb_class_name(klass));
  9. }
  10.  
  11. str = rb_str_buf_new2("#<");
  12. klass = rb_class_name(klass);
  13. rb_str_buf_append(str,klass);
  14. rb_str_buf_cat(str,": ",2);
  15. rb_str_buf_append(str,exc);
  16. rb_str_buf_cat(str,">",1);
  17.  
  18. return str;
  19. }

有趣的是构建返回字符串.

Object#inspect,另一方面定义:

  1. static VALUE
  2. rb_obj_inspect(VALUE obj)
  3. {
  4. if (rb_ivar_count(obj) > 0) {
  5. VALUE str;
  6. VALUE c = rb_class_name(CLASS_OF(obj));
  7.  
  8. str = rb_sprintf("-<%"PRIsVALUE":%p",c,(void*)obj);
  9. return rb_exec_recursive(inspect_obj,obj,str);
  10. }
  11. else {
  12. return rb_any_to_s(obj);
  13. }
  14. }

它递归地包含具有名称和值的实例变量.

猜你在找的Ruby相关文章