产品
产品概览
Mathematica
Mathematica 学生版
Mathematica Home Edition
Wolfram
CDF Player
(免费下载)
可计算文档格式(CDF)
web
Mathematica
grid
Mathematica
Wolfram
Workbench
Wolfram
SystemModeler
Wolfram
Finance Platform
Mathematica
附加程序包
Wolfram|Alpha 产品
解决方案
解决方案概览
工程
航空航天与国防
化学工程
控制系统
电气工程
图像处理
工业工程
材料科学
机械工程
运筹学
光学
石油工程
生物技术与医药
生物信息学
医学影像
金融、统计、商业分析
精算科学
数据分析与挖掘
计量经济学
经济学
金融工程与数学
金融风险管理
统计
软件工程、内容传递
创作与出版
界面开发
软件工程
网页开发
科学
天文学
生物科学
化学
环境科学
地球科学
社会与行为科学
设计、艺术以及娱乐
游戏设计、特殊效果及衍生艺术
教育
STEM 教育倡议
高等教育
高职高专院校
中小学教育
学生
科技
可计算文档格式(CDF)
高性能并行计算(HPC)
参见:技术指南
购买
网上商店
其它购买方式
批量许可及站点许可证
联络销售部
软件
服务
升级
培训
书籍
Merchandise
技术支持
技术支持概览
Mathematica
参考资料
知识库
学习中心
技术服务
社区与论坛
培训
查看站点是否有许可证授权
Wolfram 用户门户
公司概况
关于 Wolfram Research
新闻与活动
Wolfram 博客
合作伙伴
工作机会
Mathematica
的历史
Stephen Wolfram 主页
联系我们
公司网站
全部站点
Wolfram|Alpha
演示项目
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
>
系统界面与配置
>
并行计算
>
并行计算中的资源共享
>
CriticalSection
>
Mathematica
>
核心语言
>
调整和调试
>
并行计算
>
并行计算中的资源共享
>
CriticalSection
>
MATHEMATICA 内置符号
SetSharedVariable
ParallelSubmit
WaitAll
参见 »
|
并行性
并行计算
并行计算中的资源共享
7.0版本的新功能概要
7.0的新功能: 字母列表
7.0的新功能: 系统界面和配置
更多关于 »
CriticalSection
CriticalSection
锁定关于并行计算的变量
,计算
expr
,然后释放
.
更多信息
最多允许一个具有相同锁定变量的临界区在任何并行内核上同时运行.
用于锁定的变量在主内核中不应有值.
范例
关闭所有单元
例
(1)
保护代码块不受其它线程的干扰:
如果不对进入更新代码的途径加以保护,子内核可能会覆盖结果:
保护代码块不受其它线程的干扰:
In[1]:=
In[2]:=
Out[2]=
如果不对进入更新代码的途径加以保护,子内核可能会覆盖结果:
In[3]:=
Out[3]=
推广和延伸
(1)
锁定变量的形式可以是
:
应用
(1)
单独的读写操作不是线程安全的:
使用
CriticalSection
使整个代码段不可分割(atomic):
属性和关系
(2)
通过将内核的 ID 写入锁定变量来获得锁:
共享函数可用于临界区的同步化:
使用共享变量和临界区效率较低:
可能存在的问题
(1)
锁定变量在其被用于一个临界区之前不能有值:
通过异常中断可以打破一个死锁状态:
巧妙范例
(1)
进餐的哲学家问题,无死锁:
参见
SetSharedVariable
ParallelSubmit
WaitAll
更多关于
并行性
并行计算
并行计算中的资源共享
7.0版本的新功能概要
7.0的新功能: 字母列表
7.0的新功能: 系统界面和配置
版本 7 的新功能