Perl共享变量的原子性和可见性

时间:2014-10-06 11:35:17

标签: java multithreading perl visibility atomicity

我从threads::shared描述中读到:

  

默认情况下,变量对每个线程都是私有的,每个新创建的线程都会获得每个现有变量的私有副本。此模块允许您跨不同的线程共享变量... (more)

我们说我有一个像这样的共享变量:

my $var :shared;
$var = 10;

这意味着变量仅对我创建的所有线程都存在一次。


现在关于原子性和可见性:

如果thread_A分配了一个新值,请说11:

$var = 11;

是否保证thread_B(以及我可能创建的所有其他线程)都会看到值11? 分配是以原子方式进行的吗?

或者我们是否首先在Java中获得锁定,然后执行赋值并释放锁定。并且只有使用相同锁的线程才能保证看到更新后的值?

或者这就像Java中的volatile原始变量一样?

1 个答案:

答案 0 :(得分:4)

在更新中强制执行原子性始终是一种好习惯。 Perl提供lock允许我们这样做。您可以lock变量本身 - 如果变量与线程共享,那么锁定状态也是如此。

如果更新$var,则其他线程将看到新值。

但是你确实有潜在的竞争条件,具体取决于他们何时访问它。如果这是一个问题 - lock,如果不是......继续。

请记住,$var++等操作不能保证是原子的。 (http://perldoc.perl.org/perlthrtut.html#Thread-Pitfalls%3a-Races