Difference between revisions of "Performance/FFI"

From HaskellWiki
Jump to navigation Jump to search
m (Heading levels as per wiki standards)
m (Add performance infobox)
Line 1: Line 1:
  +
{{Performance infobox}}
 
[[Category:Performance|FFI]]
 
[[Category:Performance|FFI]]
 
== Improving performance for FFI code ==
 
== Improving performance for FFI code ==

Revision as of 21:39, 8 February 2007

Haskell Performance Resource

Constructs:
Data Types - Functions
Overloading - FFI - Arrays
Strings - Integers - I/O
Floating point - Concurrency
Modules - Monads

Techniques:
Strictness - Laziness
Avoiding space leaks
Accumulating parameter

Implementation-Specific:
GHC - nhc98 - Hugs
Yhc - JHC

Improving performance for FFI code

Use "unsafe" foreign imports

If you annotate a foreign import declaration with the unsafe keyword, this indicates to the compiler that (1) the call will not invoke another Haskell function, directly or indirectly, and (2) you don't mind if any other running Haskell threads in the system are blocked for the duration of the call.

These restrictions enable the compiler to generate a much more efficient call. In particular, GHC will generate a simple inline function call for an unsafe call, but a safe call by contrast is quite heavyweight: it involves saving some state on the Haskell stack, and a couple of calls into the runtime are made in addition to the foreign call itself.