Привет всем, у меня есть реализация неизменяемого массива, которая выглядит так:
public static final class FixedArray<T> {
private final T[] array;
public final int Length;
@SafeVarargs
public FixedArray(T... args) {
array = args;
Length = args.length;
}
public T Get(int index) {
return array[index];
}
}
public static final class FixedIntArray {
private final int[] array;
public final int Length;
public FixedIntArray(int... args) {
array = args;
Length = args.length;
}
public int Get(int index) {
return array[index];
}
}
public static final class FixedLongArray {
private final long[] array;
public final int Length;
public FixedLongArray(long... args) {
array = args;
Length = args.length;
}
public long Get(int index) {
return array[index];
}
}
Изначально я думал, что она гарантированно поточно-ориентирована.Но после прочтения обсуждения , касающегося неизменяемых массивов и модели памяти Java, я думаю, что один, я не могу быть уверен.
Я не использовал защитную копию с контрактом, которыйвызывающий код «делает правильные вещи» (и, как обычно, если он не следует контракту, поведение не определено).
Метод вызова выглядит следующим образом:
public static void main(String args[]) {
int[] ints = new int[10000];
FixedIntArray fixed_ints = new FixedIntArray(ints);
SendToThreadA(fixed_ints);
SendToThreadB(fixed_ints);
SendToThreadC(fixed_ints);
SendToThreadD(fixed_ints);
//caller (which is this method) does the right thing, ints goes out of scope without anyone trying to modify it.
}
Мне было интересно, гарантированно ли приведенный выше код является поточно-ориентированным?