[Haskell-cafe] Re: What I wish someone had told me...

Jonathan Cast jonathanccast at fastmail.fm
Wed Oct 15 19:09:09 EDT 2008


On Wed, 2008-10-15 at 13:01 -0700, Daryoush Mehrtash wrote:
> I am having hard time understanding this statement:
> 
>         Haskell types lack constructors, so the user never expects to
>         be
>         able to conjure up a value of an unknown type.
> 
> I am not sure how say in a Java language a constructor can "conjure up
> a value of an unknown type".

Well, that's the point.  It can't, in Haskell or in Java.  If you
understand that --- that you can't call the default constructor of a
class that is not statically known at compile time --- then there's no
`gotcha', in Haskell or Java.  The gotcha in Java is that every type
that actually exists does in fact have a default constructor, and every
type of the form Set<T> actually has a copy constructor, and so on.  But
if T isn't statically known at compile time, you can't call it, even
though it's guaranteed to exist.  In Java, even if I know nothing else
about a class T, I know that Set<T> has a copy constructor.  So I can
get into the habit of calling the Set<T> copy constructor, without
paying attention to whether T is statically known or not --- which
breaks when T is a generic parameter.

So Haskell lacks the `gotcha' because you never get into the bad habit
of assuming every type has a constructor in the first place.

jcc





More information about the Haskell-Cafe mailing list