⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 arithmeticparsers.scala

📁 JAVA 语言的函数式编程扩展
💻 SCALA
字号:
package examples.parsingimport scala.util.parsing.combinator1.syntactical.StandardTokenParsersobject ArithmeticParsers extends StandardTokenParsers {     lexical.delimiters ++= List("(", ")", "+", "-", "*", "/")  def expr: Parser[Any] = term ~ rep("+" ~ term | "-" ~ term)  def term = factor ~ rep("*" ~ factor | "/" ~ factor)  def factor: Parser[Any] = "(" ~ expr ~ ")" | numericLit  def main(args: Array[String]) {    val tokens = new lexical.Scanner(args(0))    println(args(0))    println(phrase(expr)(tokens))  }}object ArithmeticParsers1 extends StandardTokenParsers {     lexical.delimiters ++= List("(", ")", "+", "-", "*", "/")  val reduceList: Int ~ List[String ~ Int] => Int = {    case i ~ ps => (i /: ps)(reduce)   }  def reduce(x: Int, r: String ~ Int) = (r: @unchecked) match {    case "+" ~ y => x + y    case "-" ~ y => x - y    case "*" ~ y => x * y    case "/" ~ y => x / y  }  def expr  : Parser[Int] = term ~ rep ("+" ~ term | "-" ~ term) ^^ reduceList  def term  : Parser[Int] = factor ~ rep ("*" ~ factor | "/" ~ factor) ^^ reduceList  def factor: Parser[Int] = "(" ~> expr <~ ")" | numericLit ^^ (_.toInt)  def main(args: Array[String]) {    val tokens = new lexical.Scanner(args(0))    println(args(0))    println(phrase(expr)(tokens))  }}class Exprcase class BinOp(op: String, l: Expr, r: Expr) extends Exprcase class Num(n: Int) extends Exprobject ArithmeticParsers2 extends StandardTokenParsers {     lexical.delimiters ++= List("(", ")", "+", "-", "*", "/")  val reduceList: Expr ~ List[String ~ Expr] => Expr = {    case i ~ ps => (i /: ps)(reduce)   }  def reduce(l: Expr, r: String ~ Expr) = BinOp(r._1, l, r._2)  def mkNum(s: String) = Num(s.toInt)  def expr  : Parser[Expr] = term ~ rep ("+" ~ term | "-" ~ term) ^^ reduceList  def term  : Parser[Expr] = factor ~ rep ("*" ~ factor | "/" ~ factor) ^^ reduceList  def factor: Parser[Expr] = "(" ~> expr <~ ")" | numericLit ^^ ((s: String) => Num(s.toInt))  def main(args: Array[String]) {    val parse = phrase(expr)    val tokens = new lexical.Scanner(args(0))    println(args(0))    println(parse(tokens))  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -