我们有一个解析输入字符串的多线程 RPC 服务器。我们遇到了一个问题,Scala 的解析器组合库不是多线程安全的:Parsers.scala 中的 var lastNoSuccess被任何解析使用。我们在这一行得到一个 NullPointerException
if (!(lastNoSuccess != null && next.pos < lastNoSuccess.next.pos))
通过创建扩展其中一个解析器的对象来实现解析器的默认方法,但我想按需构造一个解析器,因此每个解析器都有自己的内部状态,所以我使用的是类而不是对象。但是,我无法编译它,因为我需要对结果进行模式匹配:
import scala.util.parsing.combinator.RegexParsers
class SqlParserImpl
extends RegexParsers
{
val term: Parser[String] = """(?i)term\b""".r
}
object Test
{
def main(args: Array[String]): Unit =
{
val parser = new SqlParserImpl
parser.parseAll(parser.term, "term") match {
// How do I match?
case SqlParserImpl#Success(result, _) => true
case SqlParserImpl#NoSuccess => false
}
}
}
失败
t.scala:16: error: '=>' expected but '#' found.
case SqlParserImpl#Success(result, _) => true
^
t.scala:17: error: '=>' expected but '#' found.
case SqlParserImpl#NoSuccess => false
^
two errors found