2008-03-14 05:47:17 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: funcmacro_atomic.h
|
|
|
|
// Purpose: Atomic Operation function and macro group docs
|
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id: funcmacro_gdi.h 52454 2008-03-12 19:08:48Z BP $
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-14 05:47:17 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
@defgroup group_funcmacro_atomic Atomic Operations
|
|
|
|
@ingroup group_funcmacro
|
|
|
|
|
|
|
|
When using multi-threaded applications, it is often required to access or
|
|
|
|
modify memory which is shared between threads. Atomic integer and pointer
|
|
|
|
operations are an efficient way to handle this issue (another, less efficient,
|
2008-03-19 08:02:01 +00:00
|
|
|
way is to use a wxMutex or wxCriticalSection). A native implementation exists
|
|
|
|
for Windows, Linux, Solaris and Mac OS X; for others, a wxCriticalSection is
|
|
|
|
used to protect the data.
|
2008-03-14 05:47:17 +00:00
|
|
|
|
2008-03-19 08:02:01 +00:00
|
|
|
One particular application is reference counting (used by so-called
|
|
|
|
@ref group_class_smartpointers "smart pointers").
|
2008-03-14 05:47:17 +00:00
|
|
|
|
|
|
|
You should define your variable with the type wxAtomicInt in order to apply
|
|
|
|
atomic operations to it.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|