seq vs. pseq

Malcolm Wallace Malcolm.Wallace at cs.york.ac.uk
Fri Oct 27 11:27:48 EDT 2006


Simon Marlow <simonmarhaskell at gmail.com> wrote:

> The difference is subtle.  The semantics of seq and pseq are
> identical; however,  GHC can see that seq is strict in both its
> arguments and hence could choose to  evaluate them in either order,
> whereas pseq is only strict in its first argument  as far as the
> strictness analyser is concerned.  The point is that pseq is  useful
> for controlling evaluation order, which is what you want for adding 
> parallelism to a program.  seq, on the other hand, is not useful for
> controlling  evaluation order.

This is a rather weird thing, and I would consider it a bug in the
Haskell Report, rather than a bug in ghc.  (It bites hard when you are
trying to implement something like HPC.)

The very name 'seq' surely suggests that you are controlling the
evaluation order.  "Please evaluate this thing on the left first".  But
that is _not_ what the Haskell Report says!  Ghc takes the Report
literally, and so the thing on the right is just as likely to be
evaluated before the thing on the left!

Surely the language designers did not intend this consequence.  For
Haskell-prime, can we fix this bug, and ensure that 'seq' really implies
ordering of evaluation?

[ If you just want strictness annotations, with the compiler free to
  reorder computations, I would say ($!) is a better bet, and could be
  redefined to use not the natural `seq`, but the strict-in-both-arguments
  variation. ]

Regards,
    Malcolm


More information about the Glasgow-haskell-users mailing list