Marco Acierno
Marco Acierno

Reputation: 14847

Debugger cannot see local variable in a Lambda

I noticed that when I hover my mouse over a local variable when my debugger is stopped inside a lambda it will report Cannot find local variable 'variable_name' even if it's visible inside the lambda and it's used.

Example code

public class Main {
    public static void main(String[] args) {
        String a = "hello_world";
        m1(a);
    }

    private static void m1(String a) {
        AccessController.doPrivileged((PrivilegedAction<String>) () -> {
            System.out.println("blala " + a);
            return "abc";
        });
    }
}

Try with a breakpoint in System.out.println("blala " + a); and after return "abc" and it always report the same error.

enter image description here

I used AccessController.doPrivileged because it's what I used in my original code and of course i'm using Java 8.

It says the same thing in Watchers and Evaluate Expression.

I tried using the "anonymous class" version and the debugger sees the value of a correctly

enter image description here

private static void m1(String a) {
    AccessController.doPrivileged(new PrivilegedAction<String>() {
        @Override
        public String run() {
            System.out.println("blala " + a);
            return "abc";
        }
    });
}

I'm missing something about lambda expressions or it's an IntellIJ IDEA 14 bug?

I don't want to report the bug right now because I already reported a bug that was caused by my code instead of IntellIJ IDEA, so I want to be sure before do something (and because I don't use Java 8 so often, so I could be wrong).

Upvotes: 7

Views: 12506

Answers (2)

Nicolas Nobelis
Nicolas Nobelis

Reputation: 840

I can confirm what is written in IDEA bug report linked by Mike Rylander: this is a JDK bug and update to version 8u60_25 of the JDK solves it.

Upvotes: 3

Rylander
Rylander

Reputation: 20119

This appears to be a know issue. According to JetBrains the root causes of this behavior is with the JDK. For more info see: IDEA-126257

Upvotes: 8

Related Questions