1
    import java.lang._

    import com.ximpleware._

    object Sample {

      def  main(args :Array[String])=  {

        // println("helloo")

         try{
             var i :Int = -1

             val vgen :VTDGen= new VTDGen()
             val ap :AutoPilot =new AutoPilot()


             ap.selectXPath("CATALOG/CD/COUNTRY/text()")
             if(vgen.parseFile("../catalog.xml", false)) {
                 val vnav :VTDNav = vgen.getNav()

                 ap.bind(vnav)

                 while((i=ap.evalXPath)!= -1) {


                  println(vnav.toString(i))
                  println(vnav.toNormalizedString(vnav.getText()))
            }

           ap.resetXPath()
         }
      }
      catch {
          case e :Exception => println(e)
      }
     }
    }

我已经导入了 VTD-XML 库它编译得很好但是在执行时会打印一个异常

:java.lang.ArrayIndexOutOfBoundsException: -1

我已经解决了代码中的while问题。但问题是我总是得到-1ap.evalXPAth

4

2 回答 2

4

我相信答案就在这条线上

while((i=ap.evalXPath)!= -1) {

在 Scala 中,赋值返回 Unit(相当于 Java 中的 void),因此这个循环不能终止。例如下面的程序无限循环

scala> var i = 0
i: Int = 0

scala> while((i = i + 1) != 10) { println(i) }
<console>:7: warning: comparing values of types Unit and Int using `!=' will always yield true
       while((i = i + 1) != 10) { println(i) }
于 2011-02-26T13:16:43.007 回答
1

正如约翰麦克雷所说;while 检查不会在 scala 中运行。相反,您可以为 -1 结束调用定义一个新的 while 结构:

def whileNotEmpty(whileF: () => Int)(doF: (Int) => Unit): Unit = { 
  val n = whileF()
  if (n != -1) { 
    doF(n)
    whileNotEmpty(whileF)(doF) 
  } 
}

这是一个从键盘读取直到您给出 -1 的调用的简化示例:

whileNotEmpty(() => Console.readLine.toInt) { 
  n => println(n) 
}
于 2011-02-26T20:48:02.387 回答