1 回答

TA貢獻(xiàn)1804條經(jīng)驗(yàn) 獲得超2個(gè)贊
不知道為什么我沒(méi)有嘗試傳遞 java Iterable 接口的實(shí)現(xiàn)......
這是修改后的工作版本,以考慮在具有類(lèi)似 Stream 的 scala 類(lèi)型時(shí)的轉(zhuǎn)換。
def toNestedJavaMap(caseClass: AnyRef): util.Map[String, Any] =
(new java.util.HashMap[String, Any]() /: caseClass.getClass.getDeclaredFields) { (accumulator, field) =>
field.setAccessible(true)
val value = field.get(caseClass) match {
case listInstance: Stream[AnyRef] => listInstance.map(toNestedJavaMap).toList.asJava
case caseClassInstance: Product => toNestedJavaMap(caseClassInstance)
case x => x
}
accumulator.put(field.getName, value)
accumulator
}
添加回答
舉報(bào)