微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

封闭范围中定义的局部变量日志必须是final或有效的final

如何解决封闭范围中定义的局部变量日志必须是final或有效的final

该消息说,到底是什么问题:你的变量 必须是最后的(即:携带关键字决赛),也可以有效地最终(即:你只有一个值分配给它 一旦 拉姆达外)。否则,您将无法在lambda语句中使用该变量。

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

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

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

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

因此,长话短说:

  • 变量必须像
  • 您不能 局部变量!
  • 或相反:如果您需要写一些东西,则必须使用周围类的字段(例如,或提供回调方法

解决方法

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

封闭范围中定义的局部变量日志必须是final或有效的final

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

    filteredRdd.map(log -> {

        placeHolder.forEach(text -> {

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

        });

        return log;

    });

    return null;
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。