8043179: Lambda expression can mutate final field
Reviewed-by: vromero
This commit is contained in:
parent
147f3473d4
commit
c00d0885ae
@ -2856,6 +2856,11 @@ public class Flow {
|
|||||||
int nextadrPrev = nextadr;
|
int nextadrPrev = nextadr;
|
||||||
ListBuffer<PendingExit> prevPending = pendingExits;
|
ListBuffer<PendingExit> prevPending = pendingExits;
|
||||||
try {
|
try {
|
||||||
|
// JLS 16.1.10: No rule allows V to be definitely unassigned before a lambda
|
||||||
|
// body. This is by design: a variable that was definitely unassigned before the
|
||||||
|
// lambda body may end up being assigned to later on, so we cannot conclude that
|
||||||
|
// the variable will be unassigned when the body is executed.
|
||||||
|
uninits.excludeFrom(firstadr);
|
||||||
returnadr = nextadr;
|
returnadr = nextadr;
|
||||||
pendingExits = new ListBuffer<>();
|
pendingExits = new ListBuffer<>();
|
||||||
for (List<JCVariableDecl> l = tree.params; l.nonEmpty(); l = l.tail) {
|
for (List<JCVariableDecl> l = tree.params; l.nonEmpty(); l = l.tail) {
|
||||||
|
@ -0,0 +1,13 @@
|
|||||||
|
/*
|
||||||
|
* @test /nodynamiccopyright/
|
||||||
|
* @summary Verify lambda expression can't mutate a final field
|
||||||
|
* @bug 8043179
|
||||||
|
* @compile/fail/ref=LambdaMutateFinalField.out -XDrawDiagnostics LambdaMutateFinalField.java
|
||||||
|
*/
|
||||||
|
class LambdaMutateFinalField {
|
||||||
|
final String x;
|
||||||
|
LambdaMutateFinalField() {
|
||||||
|
Runnable r1 = () -> x = "not ok";
|
||||||
|
this.x = "ok";
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,2 @@
|
|||||||
|
LambdaMutateFinalField.java:10:29: compiler.err.var.might.already.be.assigned: x
|
||||||
|
1 error
|
@ -0,0 +1,13 @@
|
|||||||
|
/*
|
||||||
|
* @test /nodynamiccopyright/
|
||||||
|
* @summary Verify lambda expression can't mutate a final variable
|
||||||
|
* @bug 8043179
|
||||||
|
* @compile/fail/ref=LambdaMutateFinalVar.out -XDrawDiagnostics LambdaMutateFinalVar.java
|
||||||
|
*/
|
||||||
|
class LambdaMutateFinalVar {
|
||||||
|
LambdaMutateFinalVar() {
|
||||||
|
final String x;
|
||||||
|
Runnable r1 = () -> x = "not ok";
|
||||||
|
x = "ok";
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,2 @@
|
|||||||
|
LambdaMutateFinalVar.java:10:29: compiler.err.var.might.already.be.assigned: x
|
||||||
|
1 error
|
Loading…
x
Reference in New Issue
Block a user