我是lambda和Java8的新手。我面临以下错误。


public JavaRDD<String> modify(JavaRDD<String> filteredRdd) {

    filteredRdd.map(log -> {

        placeHolder.forEach(text -> {

            //error comes here
            log = log.replace(text, ",");

        });

        return log;

    });

    return null;
}

最佳答案

该消息确切地说明了问题所在:变量日志必须是final(即:携带关键字final)或有效final(即:您仅在lambda之外为它分配一个值)。否则,您将无法在lambda语句中使用该变量。

但是,当然,这与您使用日志有冲突。关键是:您不能在lambda内部写任何东西……因此您必须退后一步,为自己打算做的事情寻找其他方式。

从这个意义上说:只要相信编译器即可。

除此之外,还有一个核心要理解:您可以而不是使用可以写入的局部变量。局部变量在运行时被“复制”到lambda的上下文中,并且为了实现确定性行为,只能将其读取,并且应该是常量

如果您的用例是写某个对象,那么它应该是您的封闭类的一个字段!

因此,长话短说:

  • 在lambda中使用(读取)的本地变量必须像常量
  • 您不能写入本地变量!
  • 或相反:如果您需要写一些东西,则必须使用周围类的字段,例如(或提供回调方法)
  • 09-30 15:16
    查看更多