Scala 封装可break和continue的foreach循环

发现scala里没有break和continue, 有时候实在是需要的话就要自己try catch异常,代码看起来有点蛋疼, 所以封装了一个可break和continue的foreach.

import scala.collection.TraversableLike

case class Breakable() {

  def break: Unit = throw BreakException

  def continue: Unit = throw ContinueException

  def foreach(t: TraversableLike[_, _], op: Any => Unit): Unit = {
    try {
      t.foreach(i => {
        try {
          op(i)
        } catch {
          case ex: Exception =>
            if (ex != ContinueException) throw ex
        }
      })
    } catch {
      case ex: Exception =>
        if (ex != BreakException) throw ex
    }
  }

  object BreakException extends Exception

  object ContinueException extends Exception

}

  

 

 

使用

 

import com.myTest.util.Breakable

/**
 * Created by Administrator on 2017/2/25 0025.
 */
object TestCode {
  def main(args: Array[String]) {
    val b = Breakable()
    val a = List(1,2,3,4,5,6,7,8,9)
    b.foreach(a, i => {
      if(i == 5) b.continue
      if(i == 7) b.break
      println(i)
    })
  }

}

  输出

 

1
2
3
4
6

 

posted @ 2017-03-25 16:51  DrWong  阅读(3703)  评论(0编辑  收藏  举报