<div dir="ltr">On 2 June 2013 19:53, Jacob Carlborg <span dir="ltr"><<a href="mailto:doob@me.com" target="_blank">doob@me.com</a>></span> wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">On 2013-06-01 23:08, Jonathan M Davis wrote:<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
If you don't need polymorphism, then in general, you shouldn't use a class<br>
(though sometimes it might make sense simply because it's an easy way to get a<br>
reference type). Where it becomes more of a problem is when you need a few<br>
polymorphic functions and a lot of non-polymorphic functions (e.g. when a<br>
class has a few methods which get overridden and then a lot of properties<br>
which it makes no sense to override). In that case, you have to use a class,<br>
and then you have to mark a lot of functions as final. This is what folks like<br>
Manu and Don really don't like, particularly when they're in environments<br>
where the extra cost of the virtual function calls actually matters.<br>
</blockquote>
<br></div>
If a reference type is needed but not a polymorphic type, then a final class can be used.</blockquote><div><br></div><div style>I've never said that virtuals are bad. The key function of a class is polymorphism.</div>
<div style>But the reality is that in non-tool or container/foundational classes (which are typically write-once, use-lots; you don't tend to write these daily), a typical class will have a couple of virtuals, and a whole bunch of properties.</div>
<div style>The majority of functions in OO code (in the sorts of classes that you tend to write daily, ie, the common case) are trivial accessors or properties. The cost of forgetting to type 'final' is severe, particularly so on a property, and there is absolutely nothing the compiler can do to help you. There's no reasonable warning it can offer either, it must presume you intended to do that.<br>
</div><div style><br></div><div style>Coders from at least C++ and C# are trained by habit to type virtual explicitly, so they will forget to write 'final' all the time.</div><div style>I can tell from hard experience, that despite training programmers that they need to write 'final', they have actually done so precisely ZERO TIMES EVER.</div>
<div style>People don't just forget the odd final here or there, in practise, they've never written it yet.</div><div style><br></div><div style>The problem really goes pear shaped when faced with the task of opportunistic de-virtualisation - that is, de-virtualising functions that should never have been virtual in the first place, but are; perhaps because code has changed/evolved, but more likely, because uni tends to output programmers that are obsessed with the possibility of overriding everything ;)</div>
<div style>It becomes even worse than what we already have with C++, because now in D, I have to consider every single method and manually attempt to determine whether it should actually be virtual or not. A time consuming and certainly dangerous/error-prone task when I didn't author the code! In C++ I can at least identify the methods I need to consider by searching for 'virtual', saving maybe 80% of that horrible task by contrast.</div>
<div style><br></div><div style>But there are other compelling reasons too, for instance during conversations with Daniel Murphy and others, it was noted that it will enhance interoperation with C++ (a key target for improvement being flagged recently), and further enabled the D DFE.</div>
<div style>I also think with explicit 'override' a requirement, it's rather non-orthogonal to not require explicit 'virtual' too.</div><div style><br></div><div style>So, consider this reasonably. At least Myself and Don have both made strong claims to this end... and we're keen to pay for it with fixing broken base classes.</div>
<div style>Is it REALLY that much of an inconvenience to people to be explicit with 'virtual' (as they already are with 'override')?</div><div style>Is catering to that inconvenience worth the demonstrable cost? I'm not talking about minor nuisance, I'm talking about time and money.</div>
</div></div></div>