参考答案:
能,Java 中可以创建 volatile 类型数组,不过只是一个指向数组的引用,而不是整个数组。我的意思是,如果改变引用指向的数组,将会受到 volatile 的保护,但是如果多个线程同时改变数组的元素,volatile 标示符就不能起到之前的保护作用了
可以创建volatile数组,但是volatile只保证对数组的引用可见,即如果是改变引用只向的数组,将受到volatile的保护,但是对多个线程想要去改变数组里面的元素,volatile不能保证。
package com.youyou;
import java.util.Arrays;
import java.util.concurrent.atomic.AtomicInteger;
/**
public class VolatileArrays {
static volatile int [] arrays= {
1,1,1,1,1
}
;
static int x=0;
static volatile int y=0;
static volatile AtomicInteger z=new AtomicInteger(0);
public static void main(String []args) {
for (int i=0;i<1000;i++) {
new Thread(new ChangeNum()).start();
}
try {
Thread.sleep(5000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Arrays.toString(arrays));
System.out.println("X:"+x);
System.out.println("Y:"+y);
System.out.println("Z:"+z);
}
static class ChangeNum implements Runnable {
@Override
public void run() {
try {
Thread.sleep(1000);
}
catch (InterruptedException e) {
e.printStackTrace();
}
arrays[0]=arrays[0]+1;
arrays[1]=arrays[1]+1;
arrays[2]=arrays[2]+1;
arrays[3]=arrays[3]+1;
arrays[4]=arrays[4]+1;
x=x+1;
y=y+1;
z.incrementAndGet();
}
}
}
运行结果:[970, 978, 982, 984, 985]
X:984
Y:986
Z:1000
从中可以看出volatile不能保证数组中的元素的可见性,并且y=y+1 也是复合操作,不具有原子性。