< prev index next >
src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntMaxVector.java
Print this page
rev 58165 : Fix the issue that unslice modifies the argument vector
Summary: Change the name of getElements() to vec() and clone argument value to
avoid it being modified
*** 56,66 ****
static final int VLENGTH = VSPECIES.laneCount();
static final Class<Integer> ETYPE = int.class;
// The JVM expects to find the state here.
! private final int[] vec; // Don't access directly, use getElements() instead.
IntMaxVector(int[] v) {
vec = v;
}
--- 56,66 ----
static final int VLENGTH = VSPECIES.laneCount();
static final Class<Integer> ETYPE = int.class;
// The JVM expects to find the state here.
! private final int[] vec; // Don't access directly, use vec() instead.
IntMaxVector(int[] v) {
vec = v;
}
*** 117,127 ****
public final int byteSize() { return VSIZE / Byte.SIZE; }
/*package-private*/
@ForceInline
final @Override
! int[] getElements() {
return VectorIntrinsics.maybeRebox(this).vec;
}
// Virtualized constructors
--- 117,127 ----
public final int byteSize() { return VSIZE / Byte.SIZE; }
/*package-private*/
@ForceInline
final @Override
! int[] vec() {
return VectorIntrinsics.maybeRebox(this).vec;
}
// Virtualized constructors
*** 476,486 ****
}
return (int) VectorIntrinsics.extract(
VCLASS, ETYPE, VLENGTH,
this, i,
(vec, ix) -> {
! int[] vecarr = vec.getElements();
return (long)vecarr[ix];
});
}
@Override
--- 476,486 ----
}
return (int) VectorIntrinsics.extract(
VCLASS, ETYPE, VLENGTH,
this, i,
(vec, ix) -> {
! int[] vecarr = vec.vec();
return (long)vecarr[ix];
});
}
@Override
*** 490,500 ****
}
return VectorIntrinsics.insert(
VCLASS, ETYPE, VLENGTH,
this, i, (long)e,
(v, ix, bits) -> {
! int[] res = v.getElements().clone();
res[ix] = (int)bits;
return v.vectorFactory(res);
});
}
--- 490,500 ----
}
return VectorIntrinsics.insert(
VCLASS, ETYPE, VLENGTH,
this, i, (long)e,
(v, ix, bits) -> {
! int[] res = v.vec().clone();
res[ix] = (int)bits;
return v.vectorFactory(res);
});
}
< prev index next >