diff -r 89d6a7a84779 -r 25a17d01db0c Symbian3/PDK/Source/GUID-088DC096-0CC7-5510-8D71-7DAF5961A681.dita --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Symbian3/PDK/Source/GUID-088DC096-0CC7-5510-8D71-7DAF5961A681.dita Fri Jan 22 18:26:19 2010 +0000 @@ -0,0 +1,12 @@ + + + + + +Using Critical Sections

Critical sections are provided to serialise access to shared resources. They are Kernel objects and, as such, are managed by the Kernel.

A critical section can only be used by threads within the same process; it cannot be used to control access to a resource shared by threads across different processes. To serialise access to a resource shared by threads across more than one process, use a mutex.

While a critical section is used to serialise access to a general resource, it is used, typically, to serialise access to a section of re-entrant code which cannot be executed concurrently by more than one thread within a process. A critical section only allows one thread into a controlled section, forcing other threads, that try to gain access to that critical section, to wait until the first thread has exited from that section.

Note that threads which do not attempt to gain access to the critical section are not blocked.

A critical section is implemented using a semaphore.

Access to a critical section object is through an RCriticalSection handle.

\ No newline at end of file