1

鉴于以下代码读取电子邮件并解析它们......

  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返回Objectfrom message.getContent(),所以我必须测试类型。

我正在使用 Scala 2.10.2。

4

0 回答 0