The programming language market (was Re: [Haskell-cafe] Why functional
programming matters
Paul Johnson
paul at cogito.org.uk
Sat Jan 26 10:45:36 EST 2008
Evan Laforge wrote:
>
> Java's just wordy like that. In python you'd say max(foos, key=lambda
> x: x.update_time).
While this is true, I was also thinking of the typical audience SPJ
specified: senior technical people and managers. Most of these people
have heard of Python and Ruby, but see them as "scripting" languages
that are not suitable for Real Work. Most of the ones I have met seem
to regard a static type system and compilation to native code as
prerequisites for "real" programming languages (although Java has
greatly weakened the second prejudice).
More importantly, these people have not read "Beating the Averages".
They see the programming language market as a Keynsian Beauty Contest,
in which the judges get rewarded for voting for the most popular
candidate. Therefore the trick to winning the contest is not persuading
the judges that you are the most beautiful, but that you are the one
that most of the other judges are going to vote for. Paradoxically this
is best done by emphasising your similarity with what they already
know. The message is "I'm just like her, only better".
In the case of Haskell ways to do this would include:
* Outline (single Powerpoint slide) a mapping between UML class
diagrams and Haskell data and class types. Mention that Haskell
classes and data types correspond roughly to Java interface and
implementation classes respectively.
* Emphasise that Haskell *is* statically type checked, its just that
type inference means you don't have to declare the type of every
single thing. Repeat this point three or four times during the
talk to make sure it sticks.
* Mention the covariance type hole in Java and say that Haskell
doesn't have it. In Haskell "static type system" means what it says.
* Hackage does what Doxygen and Javadoc do. The ones who know about
automatic documentation will get a warm fuzzy feeling. The ones
who don't will find it interesting. Also mention Hunit. Mention
QuickCheck in passing, but don't dwell on it because its not what
they know.
* Mention that there is an Eclipse plug-in for Haskell.
* Talk at length about the Haskell library and package mechanisms.
Large projects often have multi-version configuration management
issues, so talk about how library versions can be selected at
compile time by a configuration file.
* Talk about the FFI interface. Most of these people have big
important monoliths of legacy code that they don't like to talk
about in public.
* Trying to dereference "null" is a significant source of bugs, so
explain that null references are impossible in Haskell. If you
have "x :: Foo" then "x" can never be null; it *has* to refer to a
Foo object. If we want a possible null value then we say "Maybe
Foo" to signal this, and type safety means you have to account for
possible "Nothing" values.
* Say "computers are cheap but programmers are expensive" whenever
explaining a correctness or productivity feature.
The best way to demonstrate the innate productivity improvement in
Haskell is using numbers. Haskell projects to re-implement existing
code routinely report 4-fold or better code reduction. The 1993 paper
on Ada vs Awk vs C++ vs Haskell... is still good ammunition, as are the
GetOpts implementations in C and Haskell.
A lot of this is to demonstrate that the normal development
infrastructure is actually available. This is another thing that these
people expect to see in a "real" language. Its not that this is
important for productivity, its just stuff you have to have to be
considered a "real" language.
Maybe I should write a "Real Programming Languages Eat Lots of Quiche"
piece.
Paul.
More information about the Haskell-Cafe
mailing list