It's so easy to forget to mark a constructor "explicit": adding/removing args, making them optional etc. the single reliable way I know is to declare every constructor as explicit and then remove this keyword only if implicitness is required by design (thanks to the standard that allows this not only on single-argument constructors). But this would look ugly.
not intended implicit constructors open usage of (mistaken) implicit conversion, e.g. as here. this can happen by accident, or can break backward compatibility
so why "explicit" is not default characteristic of a constructor if this would lead to fewer bugs?
p.s. yeah, I read Stroustrup's "The Design and Evolution of C++", just don't remember if he says anything about "explicit" there
Backward compatibility at the time when explicit was added. The language was evolving and changing meaning of existing constructs in an evolving language is a sure way to make your users angry. It is still the case now, backward compatibility is something high in the mind of the comittee.
Because when C++ was conceived it was considered that nobody would write stupid code, and everybody would enjoy the benefits that nice implicit conversions would bring in avoiding having to write casts everywhere.
Of course, this turned out to be false, and really there are buggy constructors all over the place. Such a shame.
Interesting vantage point. I would tend to take the other side, and wonder why you think you need to mark all your constructors explicit
until proved otherwise?
Honestly I don't know the answer to your question, if there even is one. Backwards compatibility seems like it might be a contender for most-likely-reason, but again: why do you wish to prevent implicit conversion?
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With