Why D const is annoying
Jonathan M Davis
jmdavisProg at gmx.com
Tue May 1 21:23:18 PDT 2012
On Tuesday, May 01, 2012 21:05:11 Mehrdad wrote:
> Okay, so let's say you're right
>
> void process1(Student s) { .. }
> void process2(const(Student) s) { ... }
>
> and that what I guess what I REALLY want is to say, "process1() won't
> change the student's name, birthday, or any other attribute, but process2()
> will".
>
> How do you propose I make that guarantee known to the compiler/caller?
> Is that not the entire point of saying "const(Student)" in the first place?
Yes. And if you mark it as const, then the compiler will guarantee it. But
with something like lazy loading, the object _does_ change. In D, const
actually guarantees that a const object will not be altered, whereas C++'s
doesn't. If you have an object which you don't intend to _logically_ alter but
which whose state may change due to lazy loading, then the compiler can't give
you any real guarantees anyway without having a lazy-loading mechanism of some
sort built into the language.
In C++, the compiler can't use it to provide any real guarantees, because the
programmer is free to violate const at any time via mutable or casting away
const. Walter thinks that this makes C++'s const utterly useless (his focus is
very much on what the compiler can and can't guarantee). Most of the rest of
us disagree (it _does_ at least stop the programmer from inadvertently
mutating a const variable directly), but with Walter's take on it, there's no
way that he would have made D's const the same. And C++'s const just doesn't
provide the kind of guarantees that D requires anyway, since the fact that a
const object could actually be immutable makes it so that you can't safely
cast away const to mutate anything, regardless of whether the compiler assumes
that const objects never get altered.
The lack of logical const in D can be very annoying for some use cases, but
the fact that D's const is guaranteed then makes it much better for other use
cases. It's a tradeoff.
If all you want is something which indicates that you don't intend to alter
the logical state of a variable (but you may alter its state in other ways -
e.g. its cache), then D's compiler can't help you with that. Not even C++'s
compiler really does much for that, since its const can be circumvented so
easily. It just helps prevent you from doing it accidentally.
- Jonathan M Davis
More information about the Digitalmars-d
mailing list