delphi – “方法’%s’隐藏基类型’%s’的虚方法”.究竟隐藏着什么?

前端之家收集整理的这篇文章主要介绍了delphi – “方法’%s’隐藏基类型’%s’的虚方法”.究竟隐藏着什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在阅读了 Ian Boyd的构造函数系列问题( 1,2,3,4)后,我意识到我并没有完全掌握隐藏内容的字面含义.

我知道(纠正我,如果我错了)覆盖的唯一目的是能够具有多态行为,以便运行时可以根据实例的实际类型解析方法 – 而不是声明的类型.请考虑以下代码

  1. type
  2. TBase = class
  3. procedure Proc1; virtual;
  4. procedure Proc2; virtual;
  5. end;
  6.  
  7. TChild = class(TBase)
  8. procedure Proc1; override;
  9. procedure Proc2; // <- [DCC Warning]
  10. end;
  11.  
  12. procedure TBase.Proc1;
  13. begin
  14. Writeln('Base.Proc1');
  15. end;
  16. procedure TBase.Proc2;
  17. begin
  18. Writeln('Base.Proc2');
  19. end;
  20.  
  21. procedure TChild.Proc1;
  22. begin
  23. inherited Proc1;
  24. Writeln('Child.Proc1');
  25. end;
  26. procedure TChild.Proc2;
  27. begin
  28. inherited Proc2;
  29. Writeln('Child.Proc2');
  30. end;
  31.  
  32. var
  33. Base: TBase;
  34. begin
  35. Base := TChild.Create;
  36. Base.Proc1;
  37. Writeln;
  38. Base.Proc2;
  39. Base.Free;
  40. Readln;
  41. end.

哪个输出

Base.Proc1
Child.Proc1

Base.Proc2

TChild.Proc2 states that上的警告此方法“将隐藏对同名基础方法的访问”.我所看到的是,如果我不重写Proc2,我会失去该方法解析其实际类型的能力,而不是其基本类型.如何隐藏对base方法的访问?

此外,关于警告的文档作为警告的解决方案,声明:

First,you could specify override to
make the derived class’ procedure also
virtual,and thus allowing inherited
calls to still reference the original
procedure.

现在,如果我从’TChild'(没有多态)创建’TChild’实例,则非重写方法中的继承调用显然是指原始过程.如果我从’TBase’创建’Child’实例,则调用甚至不会解析为’TChild’方法,我怎么能调用’Inherited’来引用任何东西呢?

我有什么误会?

解决方法

Amongs其他的东西,你将无法定义
  1. TGrandChild = class(TChild)
  2. procedure Proc2; override;
  3. end;

因为TGrandChild看到的Proc2是来自TChild的非虚拟的. TChild.Proc2隐藏来自后代的TBase.Proc2.

编辑:

在回答Sertac的评论时:

  1. var
  2. Base: TBase;
  3. Child : TChild
  4. begin
  5. Child := TChild.Create;
  6. Base := Child;
  7. Base.Proc2;
  8. Child.Proc2;
  9.  
  10. Base.Free;
  11. Readln;

这将输出

  1. Base.Proc2
  2. Base.Proc2
  3. Child.Proc2

因此,似乎是对同一方法的两次调用实际上是对2种不同方法调用.这使得代码更难理解(这是不实际的)并产生意外行为.

猜你在找的Delphi相关文章