Portability | non-portable |
---|---|
Stability | experimental |
Maintainer | jed@59A2.org |
This module provides both the mutable IOCArray
which uses pinned memory on
the GC'd heap. Elements are stored according to the class Storable
. You
can obtain a pointer to the array contents to manipulate elements from
languages like C.
IOCArray
is 16-byte aligned by default. If you create a IOCArray
with
unsafeForeignPtrToIOCArray
then it may not be aligned. This will be an
issue if you intend to use SIMD instructions.
IOCArray
is equivalent to Data.Array.Storable.StorableArray
and similar
to Data.Array.IO.IOUArray
but slower. IOCArray
has O(1) versions of
unsafeFreeze
and unsafeThaw
when converting to/from CArray
.
- data IOCArray i e
- withIOCArray :: IOCArray i e -> (Ptr e -> IO a) -> IO a
- touchIOCArray :: IOCArray i e -> IO ()
- unsafeForeignPtrToIOCArray :: Ix i => ForeignPtr e -> (i, i) -> IO (IOCArray i e)
- module Data.Array.MArray
IOCArray type
Absolutely equivalent representation, but used for the mutable interface.
Foreign support
touchIOCArray :: IOCArray i e -> IO ()Source
If you want to use it afterwards, ensure that you
touchCArray
after the last use of the pointer,
so the array is not freed too early.
unsafeForeignPtrToIOCArray :: Ix i => ForeignPtr e -> (i, i) -> IO (IOCArray i e)Source
O(1) Construct a CArray
from an arbitrary ForeignPtr
. It is
the caller's responsibility to ensure that the ForeignPtr
points to
an area of memory sufficient for the specified bounds.
The overloaded mutable array interface
module Data.Array.MArray