如果我有这样的局部变量:
Increment() { int i = getFromDb(); // get count for a customer from db };
这是一个增加的实例类(每次客户 - 一个实例对象 - 进行购买),这个变量线程是否安全?我听说局部变量是线程安全的,因为每个线程都有自己的堆栈等等.
另外,我认为这个变量是共享状态吗?我在思维部门缺乏的是这个变量将与不同的客户对象(例如John,Paul等)合作,因此是线程安全的,但这是有缺陷的思维,并且在并发编程方面缺乏经验.这听起来很幼稚,但是我在并发编码方面没有很多经验,就像我一般的同步编码一样.
编辑:此外,函数调用getFromDb()不是问题的一部分,我不希望任何人猜测它的线程安全,因为它只是一个调用,指示值是从一个从数据库获取数据的函数分配的.:)
编辑2:此外,getFromDb的线程安全性得到保证,因为它只执行读取操作.
i
被声明为本地(方法)变量,因此它通常只存在于堆栈框架中Increment()
- 所以是的,i
是线程安全的......(虽然我无法评论getFromDb
).
除非:
Increment
是一个迭代器块(即使用yield return
或yield break
)
i
用于匿名方法(delegate { i = i + 1;}
)或lambda(foo => {i=i+foo;}
在上述两种情况下,有些情况下它可以暴露在堆栈外部.但我怀疑你是否也在做.
请注意,字段(类上的变量)不是线程安全的,因为它们很容易暴露给其他线程.这对于static
字段来说更加明显,因为所有线程自动共享相同的字段(线程静态字段除外).
您的语句有两个独立的部分 - 函数调用和赋值.
赋值是线程安全的,因为该变量是本地的.此方法的每个不同调用都将获得其自己的局部变量版本,每个版本存储在内存中不同位置的不同堆栈帧中.
对getFromDb()的调用可能是也可能不是线程安全的 - 取决于它的实现.