Copyright | (c) Justin Bonnar 2011 Roman Leshchinskiy 2011-2012 |
---|---|
License | BSD-style |
Maintainer | Roman Leshchinskiy <rl@cse.unsw.edu.au> |
Portability | non-portable |
Safe Haskell | None |
Language | Haskell2010 |
Primitive boxed mutable variables. This is a generalization of
Data.IORef, Data.STRef and Data.STRef.Lazy to work in
any PrimMonad
.
Synopsis
- data MutVar s a = MutVar (MutVar# s a)
- newMutVar :: PrimMonad m => a -> m (MutVar (PrimState m) a)
- readMutVar :: PrimMonad m => MutVar (PrimState m) a -> m a
- writeMutVar :: PrimMonad m => MutVar (PrimState m) a -> a -> m ()
- atomicModifyMutVar :: PrimMonad m => MutVar (PrimState m) a -> (a -> (a, b)) -> m b
- atomicModifyMutVar' :: PrimMonad m => MutVar (PrimState m) a -> (a -> (a, b)) -> m b
- modifyMutVar :: PrimMonad m => MutVar (PrimState m) a -> (a -> a) -> m ()
- modifyMutVar' :: PrimMonad m => MutVar (PrimState m) a -> (a -> a) -> m ()
Documentation
A MutVar
behaves like a single-element mutable array associated
with a primitive state token.
newMutVar :: PrimMonad m => a -> m (MutVar (PrimState m) a) Source #
Create a new MutVar
with the specified initial value.
writeMutVar :: PrimMonad m => MutVar (PrimState m) a -> a -> m () Source #
Write a new value into a MutVar
.
atomicModifyMutVar :: PrimMonad m => MutVar (PrimState m) a -> (a -> (a, b)) -> m b Source #
Atomically mutate the contents of a MutVar
.
This function is useful for using MutVar
in a safe way in a multithreaded program.
If you only have one MutVar
, then using atomicModifyMutVar
to access and modify
it will prevent race conditions.
Extending the atomicity to multiple MutVar
s is problematic,
so if you need to do anything more complicated,
using MVar
instead is a good idea.
atomicModifyMutVar
does not apply the function strictly. This means if a program
calls atomicModifyMutVar
many times, but seldom uses the value, thunks will pile up
in memory resulting in a space leak.
To avoid this problem, use atomicModifyMutVar'
instead.
atomicModifyMutVar' :: PrimMonad m => MutVar (PrimState m) a -> (a -> (a, b)) -> m b Source #
Strict version of atomicModifyMutVar
. This forces both the value stored
in the MutVar
as well as the value returned.
modifyMutVar :: PrimMonad m => MutVar (PrimState m) a -> (a -> a) -> m () Source #
Mutate the contents of a MutVar
.
modifyMutVar
does not apply the function strictly. This means if a program
calls modifyMutVar
many times, but seldom uses the value, thunks will pile up
in memory resulting in a space leak.
To avoid this problem, use modifyMutVar'
instead.
modifyMutVar' :: PrimMonad m => MutVar (PrimState m) a -> (a -> a) -> m () Source #
Strict version of modifyMutVar
.