鉴于以下代码读取电子邮件并解析它们......
val inbox = store.getFolder("Inbox")
inbox.open(Folder.READ_WRITE)
val messages = inbox.getMessages()
for (message <- messages) {
val from = InternetAddress.toString(message.getFrom())
if (from.contains(sender)) {
message.getContent() match {
case content: String => {
parse(content) match {
case Some(reading: SiteReading) => {
readings += reading
Logger.info(s"Message added. Subject: ${message.getSubject()}");
}
case _ => Logger.warn(s"Unable to process message. Ignoring. $content");
}
message.setFlag(Flags.Flag.DELETED, true);
}
case _ => Logger.error(s"Unknown message type sent from $sender.");
}
}
}
第7行,case content: String =>
真的很慢。我在想我的解析函数很慢,但是在亚毫秒对其进行分析之后,我并没有真正意识到模式匹配可能是罪魁祸首。模式匹配需要 250-300 毫秒。
因为javax.mail
返回Object
from message.getContent()
,所以我必须测试类型。
我正在使用 Scala 2.10.2。