PRODUCTS
Products Overview
Mathematica
Mathematica Student Edition
Mathematica Home Edition
Wolfram
CDF Player
(free download)
Computable Document Format (CDF)
web
Mathematica
grid
Mathematica
Wolfram
Workbench
Wolfram
SystemModeler
Wolfram
Finance Platform
Mathematica
Add-Ons
Wolfram|Alpha Products
SOLUTIONS
Solutions Overview
Engineering
Aerospace Engineering & Defense
Chemical Engineering
Control Systems
Electrical Engineering
Image Processing
Industrial Engineering
Materials Science
Mechanical Engineering
Operations Research
Optics
Petroleum Engineering
Biotechnology & Medicine
Bioinformatics
Medical Imaging
Finance, Statistics & Business Analysis
Actuarial Sciences
Data Analysis & Mining
Econometrics
Economics
Financial Engineering & Mathematics
Financial Risk Management
Statistics
Software Engineering & Content Delivery
Authoring & Publishing
Interface Development
Software Engineering
Web Development
Science
Astronomy
Biological Sciences
Chemistry
Environmental Sciences
Geosciences
Social & Behavioral Sciences
Design, Arts & Entertainment
Game Design, Special Effects & Generative Art
Education
STEM Education Initiative
Higher Education
Community & Technical College Education
Primary & Secondary Education
Students
Technology
Computable Document Format (CDF)
High-Performance & Parallel Computing (HPC)
See Also: Technology Guide
PURCHASE
Online Store
Other Ways to Buy
Volume & Site Licensing
Contact Sales
Software
Service
Upgrades
Training
Books
Merchandise
SUPPORT
Support Overview
Mathematica
Documentation
Knowledge Base
Learning Center
Technical Services
Community & Forums
Training
Does My Site Have a License?
Wolfram User Portal
COMPANY
About Wolfram Research
News
Events
Wolfram Blog
Partnerships
Employment Opportunities
History of
Mathematica
Stephen Wolfram's Home Page
Contact Us
OUR SITES
All Sites
Wolfram|Alpha
Demonstrations Project
MathWorld
Integrator
Wolfram Functions Site
Mathematica Journal
Wolfram Media
Wolfram
Tones
Wolfram Science
Stephen Wolfram
THIS IS DOCUMENTATION FOR AN OBSOLETE PRODUCT.
SEE THE
DOCUMENTATION CENTER
FOR THE LATEST INFORMATION.
DOCUMENTATION CENTER SEARCH
New to
Mathematica
?
Find your learning path
»
Mathematica
>
Systems Interfaces & Deployment
>
Parallel Computing
>
Resource Sharing in Parallel Computing
>
CriticalSection
>
Mathematica
>
Core Language
>
Tuning & Debugging
>
Parallel Computing
>
Resource Sharing in Parallel Computing
>
CriticalSection
>
BUILT-IN MATHEMATICA SYMBOL
SetSharedVariable
ParallelSubmit
WaitAll
See Also »
|
Concurrency
Parallel Computing
Resource Sharing in Parallel Computing
Summary of New Features in 7.0
New in 7.0: Alphabetical Listing
New in 7.0: Systems Interfaces & Deployment
More About »
CriticalSection
CriticalSection
locks the variables
with respect to parallel computation, evaluates
expr
, then releases the
.
MORE INFORMATION
At most one instance of a critical section with the same lock variable is allowed to run concurrently on any parallel kernel.
Variables used as locks should not have a value in the master kernel.
EXAMPLES
CLOSE ALL
Basic Examples
(1)
Protect a block of code from interference by other threads:
Without protecting access to the update code, subkernels may overwrite results:
Protect a block of code from interference by other threads:
In[1]:=
In[2]:=
Out[2]=
Without protecting access to the update code, subkernels may overwrite results:
In[3]:=
Out[3]=
Generalizations & Extensions
(1)
Lock variables can be of the form
:
Applications
(1)
Separate read and write operations are not thread-safe:
Use
CriticalSection
to make a whole code section atomic:
Properties & Relations
(2)
Locks are acquired by writing the kernel's ID into the lock variable:
Shared functions can be used for synchronization in place of a critical section:
Less efficient is the use of a shared variable and critical section:
Possible Issues
(1)
Lock variables must not have a value before being used in a critical section:
A deadlock can be broken with an abort:
Neat Examples
(1)
The dining philosophers, deadlock-free:
SEE ALSO
SetSharedVariable
ParallelSubmit
WaitAll
MORE ABOUT
Concurrency
Parallel Computing
Resource Sharing in Parallel Computing
Summary of New Features in 7.0
New in 7.0: Alphabetical Listing
New in 7.0: Systems Interfaces & Deployment
New in 7