不同的Sequentially Consistent定义指的是对于多线程程序中共享变量的操作,各个线程对共享变量操作的结果应该是具有一定时序关系的。在不同的定义下,这种时序关系有所不同。下面给出两种不同的Sequentially Consistent定义:
Java内存模型中的Sequentially Consistent:所有线程观察到的程序执行顺序必须与程序中定义的执行顺序一致。该模型的实现中,有一个主内存,线程在执行时只能访问本地内存,访问共享变量时需要进行相应操作,从而实现线程之间的同步。
C++11标准中的Sequentially Consistent:所有线程执行的结果必须与某种全局的简化顺序一致。该模型的实现中,有一个强制顺序的执行序列,所有操作必须按照这个序列的顺序执行。
由于不同的定义下,程序执行的顺序有所不同,因此对于相同的程序,可能在不同的Sequentially Consistent下得到不同的结果。以Java内存模型为例,下面给出一个简单的示例代码:
class MyClass {
int a;
int b;
public void func1() {
a = 1; // 写变量a
b = 2; // 写变量b
}
public void func2() {
int x = b; // 读变量b
int y = a; // 读变量a
System.out.println("x = " + x + ", y = " + y);
}
}
// 主线程中
MyClass obj = new MyClass();
// 线程1执行
obj.func1();
// 线程2执行
obj.func2();
根据Java内存模型的定义,当线程2执行时,变量b的写操作必须先于变量a的写操作,因此输出应该为“x = 2, y = 1”;但是如果采用C++11标准的定义,执行结果则是不确定的。
因此,在程序设计时应该注意不同的Sequentially Consistent定义下的差异,合理地使用同步