小编E C*_*ung的帖子

如何为lambda记录人类可读的字符串?

我会在这里尝试用我的措辞非常小心,因为lambda本质上只是一个方法签名和正文.

我的问题的前提是,能够保持简洁的语法lambda,并且能够使用人类可读的名称(字符串)来识别它,即当您将其注销时,这将非常有用.

以前,使用匿名类我总是可以覆盖toString.

final Runnable runnable = new Runnable() {  
  @Override public void run() { System.out.println("1"); }
  @Override public String toString() { return "anonymous-1"; }
}
Run Code Online (Sandbox Code Playgroud)

方案

以下是我发现自己需要恢复代码以便能够消除的情况

  1. 一个用法场景是你有一个lambda参数到另一个函数,在你的日志中你希望能够打印出传入的特定lambda /实现.比如,你有一个消费者拿了一个字符串,你有这个的实现,将打印出一个问候加上多种语言的字符串.将这些策略命名为"法语","用西班牙语".
  2. 你有一套Runnable说,每个都要依次应用,你想要注销该集的内容.

问题 因为没有附带toString,所以当你尝试注销lambda引用时,你会在日志中获得所有内容,例如:

MyClass$$Lambda$1/424058530@1c20c684
Run Code Online (Sandbox Code Playgroud)

途径

  1. 我想你总是可以引用lambda中的记录器并捕获它,这样当执行lambda时你可以打印一个静态字符串来识别lambda.
  2. Forego lambda善良,并恢复到匿名课程...不能有蛋糕和吃它,所以说.

欣赏人们在此期间及其周围的想法和经验.

lambda logging java-8

4
推荐指数
1
解决办法
168
查看次数

标签 统计

java-8 ×1

lambda ×1

logging ×1